qiansion/think-glide 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

qiansion/think-glide

最新稳定版本:v1.0.3

Composer 安装命令:

composer require qiansion/think-glide

包简介

ThinkPHP adapter for using Glide image manipulation library

README 文档

README

支持 ThinkPHP 官方现thinkphp6版本

Build Status Coverage Status Latest Stable Version Scrutinizer

Glide 是一个可以帮助你根据指定参数动态的生成图片内容给浏览器的图片操作库,从而实现 图片动态裁剪,打水印等,本库对 Glide 进行了一些友好的包装与扩展,屏蔽了原生库的一些底层抽象从而使得 ThinkPHP 用户可以在 ThinkPHP 项目中 更好的添加图片的动态裁剪功能。

Installation

执行下面命令安装:

$ composer require qiansion/think-glide

Usage

Quick start

由于从 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

即可得到缩小后的图片。

参数说明

参数名类型说明是否必选
sourcestring本地文件夹位置
cachestring缓存文件位置,默认在 runtime/glide 下面
cacheTimestring缓存时间,示例 +2 days, 缓存期间多次请求会自动响应 304
signKeystring安全签名
onExceptioncallable异常处理handler
baseUrlstring路由前缀,匹配到该前缀时中间件开始执行,默认是 /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 实例;

Quick reference

不止支持裁剪,glide还支持其它操作,只要传递对应参数即可,参考这里查看支持的参数:

http://glide.thephpleague.com/1.0/api/quick-reference/

Changelog

See CHANGELOG.md

License

See MIT.

统计信息

  • 总下载量: 5
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 1
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-02-09

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固