Laravel实现谷歌点图验证码【推荐】

 2866

下面带大家介绍如何使用 laravel-gridCaptcha 本地生成类似于谷歌点图验证码 ,希望对大家有所帮助!


[扩展推荐] 使用 laravel-gridCaptcha 本地生成类似于谷歌点图验证码

介绍

laravel-gridCaptcha 生成类似于谷歌点图验证码的小扩展,因为现在PHP大部分生成的验证码,对于恶意者来说很容易识别,而这套小扩展很简单但是对于机器人来说需要进行深度的机器学习,恶意者攻击的成本也就增加了,但是这套小扩展不同于谷歌验证码需要机器学习,只需要在本地配置好相应的文件即可。因为生成的验证码图片都是读取文件进行生成,所以建议使用Redis进行缓存,代码默认有使用缓存。

ps: 如有不足之处,欢迎大佬提出修改意见。

Github:https://github.com/deleteDB/laravel-captcha-grid

Packagist:https://packagist.org/packages/deletedb/laravel-captcha-grid

预览


Laravel实现谷歌点图验证码【推荐】


安装

支持 Laravel 8 以上版本:

  1. composer require deletedb/laravel-captcha-grid


配置项说明

发布配置文件

  1. php artisan vendor:publish --provider="Deletedb\Laravel\Providers\LaravelServiceProvider"
  1. config/gridcaptcha.php
  1. return [
  2.     //生成验证码图片配置
  3.     'image' => [
  4.         //验证码图片路径
  5.         'path' => env('GRID_CAPTCHA_IMAGE_PATH', storage_path('gridcaptcha\image')),
  6.         //从验证码图片路径中获取的文件后缀名
  7.         'suffix' => env('GRID_CAPTCHA_IMAGE_SUFFIX', 'jpg'),
  8.         //生成验证码质量
  9.         'quality' => env('GRID_CAPTCHA_IMAGE_QUALITY', 70),
  10.         //生产验证码宽
  11.         'wide' => env('GRID_CAPTCHA_IMAGE_WIDE', 300),
  12.         //生产验证码高
  13.         'high' => env('GRID_CAPTCHA_IMAGE_HIGH', 300),
  14.     ],
  15.     //验证码配置
  16.     'captcha' => [
  17.         //生成的验证码过期时间 单位秒
  18.         'validity' => env('GRID_CAPTCHA_IMAGE_VALIDITY', 180),
  19.         //验证码缓存的key
  20.         'cache_key' => env('GRID_CAPTCHA_IMAGE_CACHE_KEY', 'grid_captcha'),
  21.         //验证码生成的key长度
  22.         'key_length' => env('GRID_CAPTCHA_IMAGE_KEY_LENGTH', 64),
  23.         //自定义效验验证码key字段
  24.         'key_string' => env('GRID_CAPTCHA_IMAGE_KEY_STRING', 'captcha_key'),
  25.         //自定义效验验证码code字段
  26.         'code_string' => env('GRID_CAPTCHA_IMAGE_CODE_STRING', 'captcha_code'),
  27.     ],
  28. ];


使用

生成验证码

  1. <?php
  2. namespace App\Http\Controllers;
  3.  
  4. class TestController extends Controller
  5. {
  6.     /**
  7.      * 辅助函数生成验证码
  8.      * @return array
  9.      */
  10.     public function helpers()
  11.     {
  12.         return grid_captcha([
  13.             'mobile' => '100xxxxx121'
  14.         ]);
  15.     }
  16.  
  17.     /**
  18.      * 门面方式生成验证码
  19.      * @return array
  20.      */
  21.     public function facade()
  22.     {
  23.         return \Deletedb\Laravel\Facades\GridCaptcha::get([
  24.             'mobile' => '100xxxxx121'
  25.         ]);
  26.     }
  27.  
  28.     /**
  29.      * 对象方式生成验证码
  30.      * @return array
  31.      */
  32.     public function object()
  33.     {
  34.         $captcha = new \Deletedb\Laravel\GridCaptcha();
  35.         return $captcha->get([
  36.             'mobile' => '100xxxxx121'
  37.         ]);
  38.     }
  39. }

生成结果```

json5

  1. {
  2.   "hint": "猴子",//提示文本
  3.   "captcha_key": "Qh8kHYF4C....",//验证码key
  4.   "image": "data:image/jpeg;base64,/9j/...."//base64验证码图片 -- 前端渲染显示
  5. }

效验验证码

  1. <!--
  2.  
  3. 生成的是一个九宫格图片,前端需要渲染图片,并且生成九个div用于记录用户点击的宫格位置,宫格位置从 0 开始,当点击到四位的时候返回给后端进行效验 ,因为前端技术拙劣我就不放例子了欢迎大佬补充。
  4.  
  5. 大概思路:
  6. -->
  7. <div>
  8.     <!-- img 显示的是返回的验证码图片-->
  9.     <img src="data:image/jpeg;base64...." width="300" height="300" alt="" style="display: block;">
  10.     <div id="0"></div>
  11.     <div id="1"></div>
  12.     <div id="2"></div>
  13.     <div id="3"></div>
  14.     <div id="4"></div>
  15.     <div id="5"></div>
  16.     <div id="6"></div>
  17.     <div id="7"></div>
  18.     <div id="8"></div>
  19. </div>


效果:


Laravel实现谷歌点图验证码【推荐】


  1. <?php
  2. namespace App\Http\Controllers;
  3. use Illuminate\Http\Request;
  4.  
  5. class TestController extends Controller
  6. {
  7.  
  8.     /**
  9.      * 辅助函数方式效验
  10.      * @param Request $request
  11.      * @return array|false|\Illuminate\Http\JsonResponse
  12.      */
  13.     public function helpersCheck(Request $request)
  14.     {
  15.         /**
  16.          * 传参效验
  17.          */
  18.         if ($captcha_data = grid_captcha()->check('Qh8kHYF4C....', '1540') === false) {
  19.             return response()->json(['message' => '验证码错误', 'code' => 401]);
  20.         }
  21.  
  22.         /**
  23.          * 传递 Request 对象效验
  24.          */
  25.         if ($captcha_data = grid_captcha()->checkRequest($request)) {
  26.             return response()->json(['message' => '验证码错误', 'code' => 401]);
  27.         }
  28.  
  29.         return $captcha_data;
  30.     }
  31.  
  32.     /**
  33.      * 门面方式效验
  34.      * @param Request $request
  35.      * @return array|false|\Illuminate\Http\JsonResponse
  36.      */
  37.     public function facadeCheck(Request $request)
  38.     {
  39.         /**
  40.          * 传参效验
  41.          */
  42.         if ($captcha_data = \Deletedb\Laravel\Facades\GridCaptcha::check('Qh8kHYF4C....', '1540') === false) {
  43.             return response()->json(['message' => '验证码错误', 'code' => 401]);
  44.         }
  45.  
  46.         /**
  47.          * 传递 Request 对象效验
  48.          */
  49.         if ($captcha_data = \Deletedb\Laravel\Facades\GridCaptcha::checkRequest($request)) {
  50.             return response()->json(['message' => '验证码错误', 'code' => 401]);
  51.         }
  52.  
  53.         return $captcha_data;
  54.     }
  55.  
  56.     /**
  57.      * 对象方式效验
  58.      * @param Request $request
  59.      * @return array|false|\Illuminate\Http\JsonResponse
  60.      */
  61.     public function objectCheck(Request $request)
  62.     {
  63.         $captcha = new \Deletedb\Laravel\GridCaptcha();
  64.         /**
  65.          * 传参效验
  66.          */
  67.         if ($captcha_data = $captcha->check('Qh8kHYF4C....', '1540') === false) {
  68.             return response()->json(['message' => '验证码错误', 'code' => 401]);
  69.         }
  70.  
  71.         /**
  72.          * 传递 Request 对象效验
  73.          */
  74.         if ($captcha_data = $captcha->checkRequest($request)) {
  75.             return response()->json(['message' => '验证码错误', 'code' => 401]);
  76.         }
  77.  
  78.         return $captcha_data;
  79.     }
  80. }
  81.  
  82. //效验完成正确后 您可以进行业务逻辑处理,比如可以获取到上方设置在验证码中的数据 如:上方设置的是手机号,您这里可以获取验证码中的手机号,当效验成功发送短信验证码等...

效验成功返回: 返回的是您在生成验证时传递的数据,默认返回空数组

效验失败返回: false

  1. {
  2.     "mobile" : "100xxxxx121"
  3. }

本地化提示

  1. resources/lang/zh_CN/grid-captcha.php
  1. <?php
  2. //一个图片目录对应一个提示
  3. return [
  4.   'banmaxian' => '斑马线',
  5.   'gongjiaoche' => '公交车',
  6.   'heiban' => '黑板',
  7.   'honglvdeng' => '红绿灯',
  8.   'hongzao' => '红枣',
  9.   'houzi' => '猴子',
  10.   'qianbi' => '铅笔',
  11.   'shutiao' => '薯条',
  12.   'xiaofangshuan' => '消防栓',
  13.   'zhenglong' => '蒸笼',
  14. ];

新增验证码图片

例:新增一个类型为 pingguo 验证码类型的图片,需要在配置文件中的 image.path 目录下创建名为 pingguo 的目录并且把相关类型的图片文件存放在 pingguo 目录,新增一个类型至少要有四张相关类型的图片,不限制文件名,只要文件后缀名是配置文件中指定的即可如下:

  1. ─storage
  2.   └─gridcaptcha
  3.       └─image
  4.           ├─pingguo
  5.           │       1.jpg
  6.           │       10.jpg
  7.           │       11.jpg
  8.           │       12.jpg
  9.           │       13.jpg

特别说明

因为读取文件是缓存消耗I/O的操作所以我推荐使用Redis进行缓存,此工具默认使用了缓存,缓存有当前验证码图片目录信息、图片;使用Redis缓存只需要在 .env 文件修改 CACHE_DRIVER=redis ,并且添加Redis配置即可;在添加新分类之后建议删除之前的缓存,如果不进行删除将在缓存过期后自动更新。


本文网址:https://www.zztuku.com/index.php/detail-10443.html
站长图库 - Laravel实现谷歌点图验证码【推荐】
申明:本文转载于《learnku》,如有侵犯,请 联系我们 删除。

评论(0)条

您还没有登录,请 登录 后发表评论!

提示:请勿发布广告垃圾评论,否则封号处理!!

    编辑推荐