이 글은 thinkphp 자체 인증코드 관련 정보를 주로 소개하고 있어 참고할만한 가치가 있습니다. 도움이 필요한 친구들은 참고하시면 됩니다.
프런트엔드 페이지:
<p style="position:absolute;z-index:3;top:160px;left:180px;"> <img style="cursor:pointer; " src="{:U('Verify')}" onclick="this.src=this.src+'?'+Math.random()" id="safecode" style="height:50px;width:70%;"/> </p> //验证码判断 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 \Think\Verify($cfg); $very->entry(); } //客户端通过ajax,实现校验验证码 public function checkVerify(){ $code = I('get.code'); $very = new \Think\Verify(); $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. 인증코드를 잘못 입력한 경우 제출 후 인증코드가 자동으로 갱신됩니다.
else{ $('#safecode').attr("src","/Login/Verify?"+Math.random()); NewAlert(2,"验证码有误,请重新输入",null); code_ok = false; $('#verifyresult').html(msg.cont).css({'color':'red','font-size':'12px'}); }
3 다음은 백그라운드 검증에 대한 Ajax 제출 검증 코드입니다.
관련 권장 사항:
thinkPHP 프레임워크는 바코드 생성 방법을 구현합니다
위 내용은 Thinkphp에는 인증 코드에 대한 포괄적인 분석이 포함되어 있습니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!