首页 > 作文

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

更新时间:2023-04-08 18:31:47 阅读: 评论:0

۩ 背景

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

环境

框架版本: thinkphp5.1.2运行环境: centos7.2、phpstudy2017、nginx

功能开发

1).引入第三方扩展包

进行 tp5 的开发,compor 的使用会成为重要南安香草世界好玩吗技能,以 windows 为例子,输入命令:

compor 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>

3). captcha 扩展包代码优化

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

fun50201ction 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_i第一次亲密接触mg() 方法代码.

此时的验证码图片即可实现点击 实时苏州旅游攻略刷新 功能.

【注意: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验证码内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!

本文发布于:2023-04-08 18:31:45,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/63e3867505e214473d6e0f3cd09fc506.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:ThinkPHP5.1验证码功能实现的示例代码.doc

本文 PDF 下载地址:ThinkPHP5.1验证码功能实现的示例代码.pdf

标签:验证码   代码   功能   建议
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图