ThinkPHP5.1验证码功能实现的示例代码


Posted in PHP onJune 08, 2020

۩ 背景

ThinkPHP5.1 已经出现很久了,最近有所接触,下面介绍一下常用的第三方验证码功能的使用。

ThinkPHP5.1验证码功能实现的示例代码

环境

  • 框架版本: ThinkPHP5.1.2
  • 运行环境: CentOS7.2、phpStudy2017、Nginx

♜ 功能开发

1).引入第三方扩展包

进行 TP5 的开发,Composer 的使用会成为重要技能,以 windows 为例子,输入命令:

composer require topthink/think-captcha

完成上述操作,会在以下目录中出现 captcha 的扩展包

..\vendor\topthink\think-captcha

2).前端设置

在前端页面需要显示验证码的位置,补充 {:captcha_img()} 即可,个人代码举例如下:

<p class="pass-form-item">
  <label class="pass-label">验证码</label>
  <input type="text" name="verifyCode" class="pass-text-input " placeholder="请输入验证码">
  <div>{:captcha_img()}</div>
</p>

ThinkPHP5.1验证码功能实现的示例代码

3). captcha 扩展包代码优化

如果按照上述操作,显示的验证码图片并不能点击刷新,可自己根据需求进行刷新功能设计;或者,建议进行下面的代码优化:

function captcha_img($id = "")
{
 $js_src = "this.src='".captcha_src()."'";
 return '<img src="' . captcha_src($id) . '" title="点击更新验证码" alt="点击更新验证码" οnclick="'.$js_src.'" />';
 //return '![](' . captcha_src($id) . ')';
}

打开 ..\vendor\topthink\think-captcha\src\helper.php 文件,替换上面的 captcha_img() 方法代码.

此时的验证码图片即可实现点击 实时刷新 功能.

【注意:2020-02-26】

最近发现,直接在CSDN上复制上面的代码,“onclick” 粘贴后不是正常的代码,注意 “o”字母,建议有问题时可手打一下即可!

4). 后台代码验证

根据前端请求而来的 verifyCode 数据,调用 helper.php 中的 captcha_check() 方法,进行验证。

if(request()->isPost()){
   $data = input('post.');
   if(!captcha_check($data['verifyCode'])) {
    // 校验失败
    $this->error('验证码不正确');
   }
}

♞ 提示

官方文档—— 【ThinkPHP5.1 验证码指导】

  • 建议阅读 ..\vendor\topthink\think-captcha\src\helper.php 文件,及 Captcha.php ,可以进行样式的自定义.
  • 如果前端 {:captcha_img()} 有传值 id,那么后台 captcha_check() 验证也需要相应的 id 参数区分。
  • 验证结果,普遍使用 ajax 请求,以满足用户顺畅的体验.

到此这篇关于ThinkPHP5.1验证码功能实现的示例代码的文章就介绍到这了,更多相关ThinkPHP5.1验证码内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

PHP 相关文章推荐
php类
Nov 27 PHP
discuz 首页四格:最新话题+最新回复+热门话题+精华文章插件
Aug 19 PHP
java EJB 加密与解密原理的一个例子
Jan 11 PHP
解析php下载远程图片函数 可伪造来路
Jun 25 PHP
PHP中func_get_args(),func_get_arg(),func_num_args()的区别
Sep 30 PHP
php使用curl模拟登录后采集页面的例子
Nov 04 PHP
PHP中使用localhost连接Mysql不成功的解决方法
Aug 20 PHP
PHP使用array_multisort对多个数组或多维数组进行排序
Dec 16 PHP
PHP直接修改表内容DataGrid功能实现代码
Sep 24 PHP
php简单构造json多维数组的方法示例
Jun 08 PHP
Yii2.0实现生成二维码功能实例
Oct 24 PHP
PHP number_format函数原理及实例解析
Jul 14 PHP
php框架CI(codeigniter)自动加载与自主创建对象操作实例分析
Jun 06 #PHP
CI框架简单分页类用法示例
Jun 06 #PHP
简单的php购物车代码
Jun 05 #PHP
实例化php类时传参的方法分析
Jun 05 #PHP
PHP页面静态化――纯静态与伪静态用法详解
Jun 05 #PHP
PHP预定义接口――Iterator用法示例
Jun 05 #PHP
PHP中abstract(抽象)、final(最终)和static(静态)原理与用法详解
Jun 05 #PHP
You might like
Discuz! 5.0.0论坛程序中加入一段js代码,让会员点击下载附件前自动弹出提示窗口
2007/04/18 PHP
php cookies中删除的一般赋值方法
2011/05/07 PHP
PHP在线生成二维码(google api)的实现代码详解
2013/06/04 PHP
php实现的生成迷宫与迷宫寻址算法完整实例
2017/11/06 PHP
ext combox 下拉框不出现自动提示,自动选中的解决方法
2010/02/24 Javascript
在chrome浏览器中,防止input[text]和textarea在聚焦时出现黄色边框的解决方法
2011/05/24 Javascript
JavaScript等比例缩放图片控制超出范围的图片
2013/08/06 Javascript
浅析javascript中function 的 length 属性
2014/05/27 Javascript
JQuery $.each遍历JavaScript数组对象实例
2014/09/01 Javascript
js图片卷帘门导航菜单特效代码分享
2015/09/10 Javascript
Eclipse引入jquery报错如何解决
2015/12/01 Javascript
理解javascript中try...catch...finally
2015/12/25 Javascript
AngularJS基础 ng-class-odd 指令示例
2016/08/01 Javascript
Javascript中this绑定的3种方法与比较
2016/10/13 Javascript
微信 java 实现js-sdk 图片上传下载完整流程
2016/10/21 Javascript
从零开始学习Node.js系列教程之基于connect和express框架的多页面实现数学运算示例
2017/04/13 Javascript
详解angular如何调用HTML字符串的方法
2018/06/30 Javascript
vue中倒计时组件的实例代码
2018/07/06 Javascript
vue 本地环境跨域请求proxyTable的方法
2018/09/19 Javascript
浅谈ECMAScript 中的Array类型
2019/06/10 Javascript
vue 虚拟DOM的原理
2020/10/03 Javascript
通过JS判断网页是否为手机打开
2020/10/28 Javascript
[08:42]DOTA2每周TOP10 精彩击杀集锦vol.2
2014/06/25 DOTA
Python中下划线的使用方法
2015/03/27 Python
python修改操作系统时间的方法
2015/05/18 Python
利用pyinstaller或virtualenv将python程序打包详解
2017/03/22 Python
Python爬虫基础之XPath语法与lxml库的用法详解
2018/09/13 Python
Django migrations 默认目录修改的方法教程
2018/09/28 Python
详解Python:面向对象编程
2019/04/10 Python
纯CSS实现菜单、导航栏的3D翻转动画效果
2014/04/23 HTML / CSS
css3实现多个元素依次显示效果
2017/12/12 HTML / CSS
世界上最好的旅行夹克:BauBax
2018/12/23 全球购物
新闻系毕业生推荐信
2013/11/16 职场文书
申请任职学生会干部自荐书范文
2014/02/13 职场文书
管理学院毕业生自荐信范文
2014/03/10 职场文书
改作风抓落实促发展心得体会
2014/09/10 职场文书