thinkphp自带验证码全面解析
发布时间:2020-12-14 14:06:02 所属栏目:大数据 来源:网络整理
导读:前端页面: //验证码判断public function Verify(){ob_clean();//显示验证码$cfg=array('codeSet' => '0123456789',// 验证码字符集合'imageH' => 25,// 验证码图片高度'imageW' => 80,// 验证码图片宽度'length' => 4,// 验证码位数'fontttf' => '4.ttf',//
前端页面:
//验证码判断
public function Verify(){
ob_clean();
//显示验证码
$cfg=array(
'codeSet' => '0123456789',// 验证码字符集合
'imageH' => 25,// 验证码图片高度
'imageW' => 80,// 验证码图片宽度
'length' => 4,// 验证码位数
'fontttf' => '4.ttf',// 验证码字体,不设置随机获取
'fontSize' => 10,// 验证码字体大小(px)
'useNoise' => false,// 是否添加杂点
'useCurve' => false,// 是否画混淆曲线
'bg' => array(226,229,236) //背景颜色
);
$very=new ThinkVerify($cfg);
$very->entry();
}
//客户端通过ajax,实现校验验证码
public function checkVerify(){
$code = I('get.code');
$very = new ThinkVerify();
$key = $this->auth_my_code($very,$very->seKey);
// 验证码不能为空
$secode = session($key);
//对$code进行加密,在比较校验
if($this->auth_my_code($very,strtoupper($code)) == $secode['verify_code']) {
echo json_encode(array('flag'=>1,'cont'=>'验证码正确'));
}else{
echo json_encode(array('flag'=>2,'cont'=>'验证码错误'));
}
}
private function auth_my_code($vry,$str){
$key = substr(md5($vry->seKey),5,8);
$str = substr(md5($str),8,10);
return md5($key . $str);
}
以上验证码如果输入错误提交后不能自动刷新,对代码进行更改后: location.href="/Login/Login";这样只能对整个页面刷新,提交表单的值可能会丢失,非常影响用户体验。 2.如果验证码输入错误,提交后自动刷新验证码。3.以下为ajax提交验证码到后台校验:以上所述是小编给大家介绍的thinkphp自带验证码全面解析。编程之家 52php.cn 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |