为了方便自己快速添加经过精挑细选的拓展包和拓展服务
1.Laravel-Excel(Excel导入生成)
//载入拓展包:在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(微信开发封装)
//载入拓展包:执行命令
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(二维码生成)
//载入拓展包:在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')
后续将持续更新其他优秀拓展包