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 文件上传系统手记
Oct 26 PHP
PHP的cURL库功能简介 抓取网页、POST数据及其他
Apr 07 PHP
zend api扩展的php对象的autoload工具
Apr 18 PHP
php cli模式学习(PHP命令行模式)
Jun 03 PHP
Java和PHP在Web开发方面对比分析
Mar 01 PHP
PHP中使用register_shutdown_function函数截获fatal error示例
Apr 21 PHP
PHP 二维数组和三维数组的过滤
Mar 16 PHP
php 微信公众平台开发模式实现多客服的实例代码
Nov 07 PHP
PHP实现移除数组中为空或为某值元素的方法
Jan 07 PHP
php插件Xajax使用方法详解
Aug 31 PHP
实例介绍PHP中zip_open()函数用法
Feb 15 PHP
PHP SESSION机制的理解与实例
Mar 22 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
Nginx下配置codeigniter框架方法
2015/04/07 PHP
laravel框架中控制器的创建和使用方法分析
2019/11/23 PHP
jquery.boxy插件的iframe扩展代码
2010/07/02 Javascript
用Javascript评估用户输入密码的强度(Knockout版)
2011/11/30 Javascript
jQuery getJSON()+.ashx 实现分页(改进版)
2013/03/28 Javascript
Jquery取得iframe下内容的方法
2013/11/18 Javascript
Js实现双击鼠标自动滚动屏幕的示例代码
2013/12/14 Javascript
javascript中普通函数的使用介绍
2013/12/19 Javascript
jQuery循环滚动新闻列表示例代码
2014/06/17 Javascript
Backbone.js 0.9.2 源码注释中文翻译版
2015/06/25 Javascript
js仿百度切换皮肤功能(html+css)
2016/07/10 Javascript
jQuery 全选 全部选 反选 实现代码
2016/08/17 Javascript
微信小程序开发之选项卡(窗口底部TabBar)页面切换
2017/04/12 Javascript
解决Layui选择全部,换页checkbox复选框重新勾选的问题方法
2018/08/14 Javascript
微信小程序自定义组件封装及父子间组件传值的方法
2018/08/28 Javascript
浅析微信扫码登录原理(小结)
2018/10/29 Javascript
jQuery实现的3D版图片轮播示例【滑动轮播】
2019/01/18 jQuery
Vue表单之v-model绑定下拉列表功能
2019/05/14 Javascript
js中offset,client , scroll 三大元素知识点总结
2019/09/11 Javascript
webpack+vue-cil 中proxyTable配置接口地址代理操作
2020/07/18 Javascript
jupyter安装小结
2016/03/13 Python
使用python读取csv文件快速插入数据库的实例
2018/06/21 Python
django中ORM模型常用的字段的使用方法
2019/03/05 Python
html5的canvas实现3d雪花飘舞效果
2013/12/27 HTML / CSS
html+js 实现markdown编辑器效果
2019/10/23 HTML / CSS
管理科学大学生求职信
2013/11/13 职场文书
职业规划书如何设计?
2014/01/09 职场文书
竞选团支书演讲稿
2014/04/28 职场文书
社会实践活动总结报告
2014/04/29 职场文书
2014各大专业毕业生自我评价
2014/09/17 职场文书
党的群众路线教育实践活动对照检查材料思想汇报(党员篇)
2014/09/25 职场文书
旷课检讨书500字
2014/10/14 职场文书
公务员群众路线心得体会
2014/11/03 职场文书
冰雪公主观后感
2015/06/16 职场文书
用Python创建简易网站图文教程
2021/06/11 Python
Python实现打乒乓小游戏
2021/09/25 Python