您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何在ThinkPHP項目里添加圖片尺寸動態裁剪功能,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
在 ThinkPHP 項目里添加圖片尺寸動態裁剪功能
首先附上項目地址: https://github.com/top-think/think-glide
Glide 是一個可以幫助你根據指定參數動態的生成圖片內容給瀏覽器的圖片操作庫,從而實現
圖片動態裁剪,打水印等,本庫對 Glide 進行了一些友好的包裝與擴展,屏蔽了原生庫的一些底層抽象從而使得 ThinkPHP 用戶可以在 ThinkPHP 項目中
更好的添加圖片的動態裁剪功能。
執行下面命令安裝:
$ composer require slince/think-glide
由于從 ThinkPHP 5.1.6 開始添加了中間件的功能,所以在
ThinkPHP 5.1.6 及以上版本使用 middleware 注冊:
打開 application/middleware.php
文件(如果不存在創建即可),注冊 middleware:
return [ //... \Slince\Glide\GlideMiddleware::factory([ 'source' => __DIR__ . '/../img', ]) ];
這種方式比較簡單,也是推薦的方式;
ThinkPHP 5.1.0 以上 5.1.6 以下版本:
不支持middleware,所以啟用過程要復雜一點,我們用下面方式來妥協:
// 在 /route/route.php 注冊下面路由 Route::get('images/:file', 'index/handleImageRequest'); //在控制器 index 里創建action public function handleImageRequest() { $middleware = \Slince\Glide\GlideMiddleware::factory([ 'source' => App::getRootPath() . '/img', ]); return $middleware(app('request'), function(){ return app('response'); }); }
source
是你本地圖片文件夾的位置,假設該目錄下有圖片 user.jpg
, 打開瀏覽器訪問下面鏈接:
http://youdomain.com/images/user.jpg?w=100&h=100
即可得到縮小后的圖片。
參數名 | 類型 | 說明 | 是否必選 |
---|---|---|---|
source | string | 本地文件夾位置 | 是 |
cache | string | 緩存文件位置,默認在 runtime/glide 下面 | 否 |
cacheTime | string | 緩存時間,示例 +2 days , 緩存期間多次請求會自動響應 304 | 否 |
signKey | string | 安全簽名 | 否 |
onException | callable | 異常處理handler | 否 |
baseUrl | string | 路由前綴,匹配到該前綴時中間件開始執行,默認是 /images | 否 |
不開啟安全簽名的情況下用戶可以調整query里面的參數自行對圖片進行裁剪,如果你不打算這么做的話,你可以通過signKey
進行校驗,
\Slince\Glide\GlideMiddleware::factory([ 'source' => __DIR__ . '/../img', 'signKey' => 'v-LK4WCdhcfcc%jt*VC2cj%nVpu+xQKvLUA%H86kRVk_4bgG8&CWM#k*' ])
這種情況下用戶自行調整參數將會無效;生成安全的URL:
echo app('glide.url_builder')->getUrl('user.jpg', ['w' => 100, 'h' => 100]); //你會得到如下鏈接:/images/user.jpg?w=100&h=100&s=af3dc18fc6bfb2afb521e587c348b904
如果用戶訪問了一張不存在的圖片或者沒有進行安全校驗,系統會拋出異常,你可以通過 onException
進行替換默認行為:
\Slince\Glide\GlideMiddleware::factory([ 'source' => __DIR__ . '/../img', 'signKey' => 'v-LK4WCdhcfcc%jt*VC2cj%nVpu+xQKvLUA%H86kRVk_4bgG8&CWM#k*', 'onException' => function(\Exception $exception, $request, $server){ if ($exception instanceof \League\Glide\Signatures\SignatureException) { $response = new Response('簽名錯誤', 403); } else { $response = new Response(sprintf('你訪問的資源 "%s" 不存在', $request->path()), 404); } return $response; } ])
注意該閉包必須返回一個 think\Response
實例;
關于“如何在ThinkPHP項目里添加圖片尺寸動態裁剪功能”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。