laravel框架常用composer拓展包或拓展服务快速查询列表

为了方便自己快速添加经过精挑细选的拓展包和拓展服务

1.Laravel-Excel(Excel导入生成)

  • github:Laravel-Excel
  • 官网:Laravel-Excel
  • 功能描述:可以把数据以Excel表格的形式导出,也可以导入Excel表格生成数据并插入数据库,同时还可以操作csv,pdf等文件。
  • 安装
//载入拓展包:在composer.json中的required中添加此条并composer update
"maatwebsite/excel": "~2.1.0"
//添加服务:添加到config.php providers数组中
Maatwebsite\Excel\ExcelServiceProvider::class,
//添加别名:添加到config.php aliases数组中
'Excel' => Maatwebsite\Excel\Facades\Excel::class,
//生成配置文件:执行命令
php artisan vendor:publish --provider="Maatwebsite\Excel\ExcelServiceProvider"
  • 使用
//导入excel方法
//$excel_file_path = 你的 Excel 文件存放地址
$excel_data = Excel::load($excel_file_path, function($reader) {
    $excel_data = Excel::load($excel_file_path)->get()->toArray();
    //直接打印内容即可看到效果
    echo 'job.xlsx 表格内容为:';
    dd($excel_data);
});`
//导出excel方法
//导出 Excel 并能直接在浏览器下载
//$export_file_name = 要生成的文件名
Excel::create($export_file_name, function ($excel) {
    $excel->sheet('Sheetname', function ($sheet) {
        $sheet->appendRow(['data 1', 'data 2']);
        $sheet->appendRow(['data 3', 'data 4']);
        $sheet->appendRow(['data 5', 'data 6']);
    });
})->download('xls');
// 导出 Excel 并存储到指定目录
Excel::create($export_file_name, function ($excel) {
    $excel->sheet('Sheetname', function ($sheet) {
        $sheet->appendRow(['data 1', 'data 2']);
        $sheet->appendRow(['data 3', 'data 4']);
        $sheet->appendRow(['data 5', 'data 6']);
    });
})->store('xls', $object_path);`
  • 注意事项
    如果Excel导入时,中文有问题,需要修改excel.php
//取消使用ascii字符集
'to_ascii' => true,改为false

2.laravel-u-editor(UEditor富文本编辑器)

//载入拓展包:在composer.json中的required中添加此条并composer update
"stevenyangecho/laravel-u-editor": "~1.4"
//添加服务:添加到config.php providers数组中
'Stevenyangecho\UEditor\UEditorServiceProvider'
//生成配置文件:执行命令
php artisan vendor:publish
  • 使用
//在视图模板中引用ueditor的js和css文件
@include('UEditor::head');
//在视图模板中创建编辑器的容器
<!-- 加载编辑器的容器 -->
<script id="container" name="content" type="text/plain">
    这里写你的初始化内容
</script>
<!-- 实例化编辑器 -->
<script type="text/javascript">
    var ue = UE.getEditor('container');
        ue.ready(function() {
        ue.execCommand('serverparam', '_token', '{{ csrf_token() }}');//此处为支持laravel5 csrf ,根据实际情况修改,目的就是设置 _token 值.    
    });
</script>

3.laravel-hashids(id加密)

//载入拓展包:执行命令
composer require vinkla/hashids
//添加服务:添加到config.php providers数组中
Vinkla\Hashids\HashidsServiceProvider::class
//添加别名:添加到config.php aliases数组中
'Hashids' => Vinkla\Hashids\Facades\Hashids::class
//生成配置文件:执行命令
php artisan vendor:publish
//修改hashids.php中的connections的盐值和加密输出长度
'connections' => [
        'main' => [
            'salt' => env('APP_KEY'),
            'length' => '16',
        ],
        'alternative' => [
            'salt' => env('APP_KEY'),
            'length' => '6',
        ],
        'recommend' => [
            'salt' => env('APP_KEY'),
            'length' => '6',
        ],
    ],
  • 使用
//在视图模板中引用ueditor的js和css文件
@include('UEditor::head');
//加密的使用方式
Hashids::encode(123);//返回经过加密后的字符串a9M4pPZqO0rJ6QWK
//解密的使用方式
//注意返回值是数组
Hashids::decode('a9M4pPZqO0rJ6QWK');//返回经过解密后的数组[123]
//同时加密多个参数
Hashids::encode(1,2,3);//M0BKxg8cYSNrVAjp
//解密多个参数的加密字符串
Hashids::decode('M0BKxg8cYSNrVAjp')//返回经过解密后的数组[1,2,3]
//切换不同的盐值和加密长度
//我们可能需要对多个不同类型的id进行加密,盐值和返回长度也各有不同。所以config的hashids中的多个数组可以派上用场了。其中main数组是作为默认连接,可以自行添加其他的加密数组。
Hashids::connection('recommend')->encode(1);
Hashids::connection('recommend')->decode("jflkasdjfkasdjfl");

4.intervention/image(图片压缩剪切处理)

//载入拓展包:执行命令
composer require intervention/image
//添加服务:添加到config.php providers数组中
Intervention\Image\ImageServiceProvider::class
//添加别名:添加到config.php aliases数组中
'Image' => Intervention\Image\Facades\Image::class
//生成配置文件:执行命令
php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravel5"
  • 使用
//传入要处理的图片文件,调用图片处理方法即可生成图片
Image::make($request->file('image'))->size(300,400)->save(public_path() . '/uploads', 30);
  • 注意事项
    保存路径是绝对路径,而不是相对路径;
    无法自动创建目录,所以要使用File Facade 来创建分类目录;
    注意保存目录的权限,如果没有读写的权限,则会保存图片失败;

5.laravel-wechat(微信开发封装)

  • github:laravel-wechat
  • 官网:easywechat
  • 功能描述:简化微信开发,可直接使用各种封装好的方法等。
  • 安装
//载入拓展包:执行命令
composer require "overtrue/laravel-wechat:~3.0"
//添加服务:添加到config.php providers数组中
Overtrue\LaravelWechat\ServiceProvider::class,
//添加别名:添加到config.php aliases数组中
'EasyWeChat' => Overtrue\LaravelWechat\Facade::class,
//生成配置文件:执行命令
php artisan vendor:publish --provider="Overtrue\LaravelWechat\ServiceProvider"
//设置参数:在.env文件中设置微信appid和密钥
WECHAT_APPID
WECHAT_SECRET
WECHAT_TOKEN
WECHAT_AES_KEY
  • 使用
//解除对该路由的csrf保护,并将路由设置成any
Route::any('/wechat', 'WechatController@serve');
//创建微信实例
 public function serve()
    {
        $wechat = app('wechat');
        $wechat->server->setMessageHandler(function($message){
            return "欢迎关注 overtrue!";
        });
        return $wechat->server->serve();
    }

6.simple-qrcode(二维码生成)

  • github:simple-qrcode
  • 官网:simple-qrcode
  • 功能描述:简单快速生成各类二维码,网站、电话、网址、文字、数字等二维码。
  • 安装
//载入拓展包:在composer.json中的required中添加此条并composer update
"simplesoftwareio/simple-qrcode": "~1"
//添加服务:添加到config.php providers数组中
SimpleSoftwareIO\QrCode\QrCodeServiceProvider::class
//添加别名:添加到config.php aliases数组中
'QrCode' => SimpleSoftwareIO\QrCode\Facades\QrCode::class
  • 使用
//直接在blade视图模板中生成并显示二维码
//此二维码好像是生成svg类型的矢量图形
<div class="visible-print text-center">
    {!! QrCode::size(100)->generate(Request::url()); !!}
    <p>扫我回到来源页</p>
</div>
//在服务器端生成二维码图片,并保存
//format是将二维码格式化成相应格式
QrCode::format('png')->generate('Embed me into an e-mail!'), 'QrCode.png', 'image/png')

后续将持续更新其他优秀拓展包

推荐阅读更多精彩内容