thinkphp验证码实现。
  TEZNKK3IfmPf 2023年11月13日 16 0

作为我大天朝的程序员,如果不会点thinkphp框架确实有点说不过去了(虽然作为菜鸟的我才入坑没几个月)。不过不会也没关系,很简单的一个php框架。今天为大家介绍的是thinkphp如何实现验证码的功能。

thinkphp自带验证码功能,我们直接调用就行了。发展到现在thinkphp已经有好几个正式版本了,最新的版本是thinkphp5.0。今天我将给大家介绍一下5的版本和3的版本。

thinkphp3的版本:

第一步:在我们相对应的控制器创建一个输出验证码方法

public function verify()
{
$Verify = new \Think\Controller\Verify();
$Verify->fontSize = 20; // 字体大小
$Verify->length = 6; // 多少个字符
$Verify->useNoise = false; // 是否添加杂点
$Verify->imageW = 233; // 验证码宽度
$Verify->imageH = 50; // 验证码高度
$Verify->entry();
}

第二步:在页面输出我们的验证码

<img src="{:U('Admin/verify')}" class="verifyCode" name="admin_verify" title="点击刷新验证码">

完成以上的操作即可。接下来,我们开始实现附加功能。

第一个点击验证码实现刷新(其实就是使用一个ajax方法再去重新加载一次图片输出而已):在我们的js中写入如下方法。

var verifyImg = $(".verifyCode");
var verifyPath = verifyImg.attr("src");
verifyImg.click(function () {
if (verifyPath.indexOf("?")>0) {
$(this).attr("src", verifyPath+'&random='+Math.random());
}else{
$(this).attr("src", verifyPath.replace(/\?.*$/,' ')+'?'+Math.random());
}
)})
// 或者直接不单独写js方法,直接给图片添加一个点击事件
<img src="{:U('Admin/verify')}" class="verifyCode" name="admin_verify" title="点击刷新验证码" onclick="this.src=\'' .{:U('Admin/verify')}. '?id=\'+Math.random();">

第二个就是后台验证我们的验证码正确性:先创建一个公共的验证函数(公共的配置函数文件是在common下面,可定义在项目的公共目录也可在模块的功能目录),在再我们接受用户信息提交的地方做验证并将错误信息反馈给用户。

// 公共的验证函数(建议放在项目的公共目录中,便于多个模块调用)
// 公共函数在系统中可以直接使用
function check_verify($code, $id = ""){
$verify = new \Think\Verify();
return $verify->check($code, $id);
}
// 接收页面传入的填写的验证码值
$data['admin_verify'] = I('post.admin_verify');
if (check_verify($data['admin_verify'])) {
$this->error("验证码不正确", U("login"), 3);
}

 thinkphp5的版本:

thinkphp5是一个历史性的变革,这里就不单独为大家介绍了。直接放大招了。

第一步:在我们的配置文件(config.php)中直接配置如下内容

/**
*需要开启url路由:'url_route_on' => true,
*/
'captcha' => [
// 验证码字符集合
'codeSet' => '2345678abcdefhijkmnpqrstuvwxyzABCDEFGHJKLMNPQRTUVWXY',
// 验证码字体大小(px)
'fontSize' => 25,
// 是否画混淆曲线
'useCurve' => true,
// 验证码图片高度
'imageH' => 30,
// 验证码图片宽度
'imageW' => 100,
// 验证码位数
'length' => 5,
// 验证成功后是否重置
'reset' => true
],

 

第二步:在我们的模板文件中输出即可

// 方式一(建议采用该方式)
<img src="{:captcha_src()}" alt="captcha" />
// 方式二
{:captcha_img()}

 

对比thinkphp3的版本,我们同样实现其他附加的功能。

第一个点击刷新:这里和thinkphp3的版本一致,就不单独介绍了。

第二个就是验证码验证:这里可以使用我们tp5内置的验证(建议),也可采用自定义验证。

// 内置验证
$this->validate($data,[
'captcha|验证码'=>'require|captcha'
]);
// 自定义验证
if(!captcha_check($captcha)){
//验证失败
};

自此thinkphp常用的版本在验证码的功能上已经介绍完了,不知道你还有什么问题没?

【版权声明】本文内容来自摩杜云社区用户原创、第三方投稿、转载,内容版权归原作者所有。本网站的目的在于传递更多信息,不拥有版权,亦不承担相应法律责任。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@moduyun.com

  1. 分享:
最后一次编辑于 2023年11月13日 0

暂无评论

推荐阅读
  TEZNKK3IfmPf   2024年05月17日   28   0   0 算法php
  TEZNKK3IfmPf   2024年03月29日   46   0   0 php
  TEZNKK3IfmPf   2024年04月19日   39   0   0 php
  TEZNKK3IfmPf   2024年04月19日   65   0   0 shellphp
  TEZNKK3IfmPf   2024年04月19日   44   0   0 php
  TEZNKK3IfmPf   2024年05月17日   49   0   0 冒泡排序php
  TEZNKK3IfmPf   2024年04月19日   38   0   0 xmlphp
  TEZNKK3IfmPf   2024年05月17日   42   0   0 数组php
  TEZNKK3IfmPf   2024年03月29日   48   0   0 数据库mysqlphp
  TEZNKK3IfmPf   2024年05月17日   50   0   0 mysqlphp
  TEZNKK3IfmPf   2024年04月19日   56   0   0 php
  TEZNKK3IfmPf   2024年05月17日   37   0   0 字符串php
TEZNKK3IfmPf