Intervention Image 是一个PHP图片操作处理库,为图片创建、修改及压缩等处理提供了便捷方式。此外,还提供了服务提供者和门面以便集成到Laravel应用中。
1、配置composer
设置镜像地址(中国的镜像地址 -g参数表示全局配置)
composer config -g repo.packagist composer https://packagist.phpcomposer.com
设置进程执行超时时间(单位秒)
composer config -g process-timeout 600
查看配置列表
composer config -g -l
配置文件说明
项目根目录下命名为composer.json的文件,使用JSON格式定义项目或者包相关的信息:
2、安装:
安装
安装Intervention Image之前,需要确保PHP版本>=5.4并且安装了Fileinfo扩展,以及GD库(>=2.0)或者Imagick扩展(>=6.5.7)。
我们使用Composer在命令行安装最新版本的Intervention Image:
composer require intervention/image
注意:不需要刻意去生成锁文件,composer
在安装新包的时候就已经更新了锁文件,以确保其他开发人员与你所用的包是一致的。其他人员只需要composer install
即可!
4、集成到Laravel
前面已经提到,Intervention Image
提供了相应的服务提供者和门面以便集成到Laravel应用。
安装好Intervention Image后,打开config/app.php
,注册如下服务提供者到$providers数组:
Intervention\Image\ImageServiceProvider::class
然后添加如下门面到$aliaes数组:
'Image' => Intervention\Image\Facades\Image::class
这样我们就可以在Laravel应用代码中直接使用Image了。
5、配置
默认情况下,Intervention Image使用PHP的GD库扩展处理所有图片,如果你想要切换到Imagick,你可以将配置文件拉到应用中:
php artisan vendor:publish --provider="Intervention\Image\ImageServiceProviderLaravel5"
这样对应的配置文件会被拷贝到config/image.php
,这样你可以在该配置文件中修改图片处理驱动配置。
6、使用示例
Route::get('/', function(){
$img = Image::make('foo.jpg')->resize(300, 200);
return $img->response('jpg');
});