• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧
您的位置:首页 > CMS教程 >建站教程 > Laravel实现谷歌点图验证码【推荐】

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

作者:站长图库 字体:[增加 减小] 来源:互联网

站长图库向大家介绍了Laravel实现验证码,laravel-gridCaptcha,谷歌点图验证码等相关知识,希望对您有所帮助

下面带大家介绍如何使用 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 以上版本:

composer require deletedb/laravel-captcha-grid


配置项说明

发布配置文件

php artisan vendor:publish --provider="Deletedb\Laravel\Providers\LaravelServiceProvider"
config/gridcaptcha.php
return [    //生成验证码图片配置    'image' => [        //验证码图片路径        'path' => env('GRID_CAPTCHA_IMAGE_PATH', storage_path('gridcaptcha\image')),        //从验证码图片路径中获取的文件后缀名        'suffix' => env('GRID_CAPTCHA_IMAGE_SUFFIX', 'jpg'),        //生成验证码质量        'quality' => env('GRID_CAPTCHA_IMAGE_QUALITY', 70),        //生产验证码宽        'wide' => env('GRID_CAPTCHA_IMAGE_WIDE', 300),        //生产验证码高        'high' => env('GRID_CAPTCHA_IMAGE_HIGH', 300),    ],    //验证码配置    'captcha' => [        //生成的验证码过期时间 单位秒        'validity' => env('GRID_CAPTCHA_IMAGE_VALIDITY', 180),        //验证码缓存的key        'cache_key' => env('GRID_CAPTCHA_IMAGE_CACHE_KEY', 'grid_captcha'),        //验证码生成的key长度        'key_length' => env('GRID_CAPTCHA_IMAGE_KEY_LENGTH', 64),        //自定义效验验证码key字段        'key_string' => env('GRID_CAPTCHA_IMAGE_KEY_STRING', 'captcha_key'),        //自定义效验验证码code字段        'code_string' => env('GRID_CAPTCHA_IMAGE_CODE_STRING', 'captcha_code'),    ],];


使用

生成验证码

<?phpnamespace App\Http\Controllers; class TestController extends Controller{    /**     * 辅助函数生成验证码     * @return array     */    public function helpers()    {        return grid_captcha([            'mobile' => '100xxxxx121'        ]);    }     /**     * 门面方式生成验证码     * @return array     */    public function facade()    {        return \Deletedb\Laravel\Facades\GridCaptcha::get([            'mobile' => '100xxxxx121'        ]);    }     /**     * 对象方式生成验证码     * @return array     */    public function object()    {        $captcha = new \Deletedb\Laravel\GridCaptcha();        return $captcha->get([            'mobile' => '100xxxxx121'        ]);    }}

生成结果```

json5

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

效验验证码

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


效果:


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


<?phpnamespace App\Http\Controllers;use Illuminate\Http\Reques
  


 
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

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

相关文章

  • uniapp中怎么实现直播旁路推流(步骤分享)
  • jQuery如何判断css是否存在
  • 禾匠4.4.8微信授权接口修复教程
  • Laravel实现随着Resource返回自定义分页信息
  • PHP中怎么解决serialize函数中文乱码的问题
  • 详解thinkphp6.0.7中怎么使用JWT
  • Photoshop绘制立体效果的紫色心形宝石
  • Navicat连接Mysql8.0.11出现1251错误怎么办
  • 使用thinkphp3.2.3开发微信授权登录详细教程
  • 小程序swiper轮播CSS3动画及跳转到指定swiper-item的使用

文章分类

  • dedecms
  • ecshop
  • z-blog
  • UcHome
  • UCenter
  • drupal
  • WordPress
  • 帝国cms
  • phpcms
  • 动易cms
  • phpwind
  • discuz
  • 科汛cms
  • 风讯cms
  • 建站教程
  • 运营技巧

最近更新的内容

    • 如何利用CSS制作一个聚光灯效果(附代码)
    • PhotoShop CS6简单制作细线格子纹理字效教程
    • 插件highcharts在thinkphp中的使用
    • Photoshop制作超酷的哥特字体教程
    • php浮点数float运算中转整型int问题
    • 用PHP将女友照片转成可爱的动漫头像!
    • 手把手带你在小程序中实现保存图片组件功能
    • ThinkPHP 6.0 多语言优化扩展包的安装与使用
    • 帝国CMS二次开发领号发号功能开发思路
    • 这几个WordPress插件存在高危漏洞!

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有