canon1014 / captcha-lumen
lumen 的验证码
2.0
2019-07-02 06:13 UTC
Requires
- php: >=5.4
- ext-gd: *
- illuminate/config: ~5.0
- illuminate/filesystem: ~5.0
- illuminate/hashing: ~5.0
- illuminate/support: ~5.0
- intervention/image: ~2.2
This package is auto-updated.
Last update: 2024-09-29 05:42:20 UTC
README
本项目基于Captcha for Laravel 5 和 lumen-captcha 修改
需求
Lumen 版本 >= v5.5
预览
安装
- 此 Package 必须开启 Redis 才能使用,因为验证码与绑定验证码的 uuid 都保存在 Redis 中。
composer require canon/captcha-lumen
如何使用
在 bootstrap/app.php
中注册 Captcha Service Provider:
$app->register(Canon\CaptchaLumen\CaptchaServiceProvider::class); class_alias('Canon\CaptchaLumen\Facades\Captcha','Captcha');
设置
在 bootstrap/app.php
中可以设定各种自定义类型的验证码属性,更多详细设定请查看 Captcha for Laravel 5
/** * captcha set */ config(['captcha'=> [ 'useful_time' => 5, //验证码有效时间(分钟) 'captcha_characters' => '2346789abcdefghjmnpqrtuxyzABCDEFGHJMNPQRTUXYZ', 'sensitive' => false, //验证码是否判断大小写 'login' => [ //验证码样式 'length' => 4, //验证码字数 'width' => 120, //图片宽度 'height' => 36, //字体大小和图片高度 'angle' => 10, //字体倾斜度 'lines' => 2, //横线数 'quality' => 90, //品质 'invert' =>false, //反相 'bgImage' =>true, //背景图 'bgColor' =>'#ffffff', 'fontColors'=>['#339900','#ff3300','#9966ff','#3333ff'],//字体颜色 ], ] ]);
如果不配置设定档,默认就是 default,验证码有效时限为 5 分钟。
示例
因为 Lumen 都是无状态的 API,所以验证码图片都会绑定一个 UUID,先获取验证码的 UUID 和图片的 URL,验证时再一并发送验证码和 UUID。
生成
获取验证码:
{Domain}/captchaInfo/{type?}
type
就是在 config 中定义的类型,如果不指定type
,默认为default
样式,Response:
{ "captchaUrl": "http://{Domain}/captcha/default/782fdc90-3406-f2a9-9573-444ea3dc4d5c", "captchaUuid": "782fdc90-3406-f2a9-9573-444ea3dc4d5c" }
captchaUrl
为验证码图片的 URL,captchaUuid
为绑定验证码图片的 uuid。
验证
在发送 Request 时将验证码和 UUID 一并送回 Server 端,在接收参数时做验证即可:
# 原版验证 # 因为我修改了存储位置也没有使用该方法作为验证所以已失效,未来将会修改 public function checkCaptcha(Request $request, $type = 'default',$captchaUuid) { $this->validate($request,[ 'captcha'=>'required|captcha:'.$captchaUuid ]); ... } # 我现在使用的 public function checkCaptchaCode($captchaId,$userCode) { $captchaId = 'captcha_'.$captchaId; $redis = app('redis.connection'); $captchaCode = $redis->get($captchaId); if(empty($captchaCode)){ return $apidoc->loginCaptchaError(); } $sensitive = config('captcha.sensitive'); if (!$sensitive){ $captchaCode = strtolower($captchaCode); $userCode = strtolower($userCode); } if($captchaCode == $userCode){ return $apidoc->loginCaptchaSuccess(); } return $apidoc->loginCaptchaError(); }
更新日志
- v1.0 (2019-07)
- 验证码图片显示错误问题
- 验证码存储位置由 Cache=>Redis
- 部分配置文件不生效
- 原版验证码修改(计划)