Maison  >  Article  >  développement back-end  >  Thinkphp est livré avec une analyse complète du code de vérification

Thinkphp est livré avec une analyse complète du code de vérification

不言
不言original
2018-06-07 10:02:421310parcourir

Cet article présente principalement les informations pertinentes sur le propre code de vérification de thinkphp. Il est très bon et a une valeur de référence. Les amis dans le besoin peuvent se référer à

Page frontale :

<p style="position:absolute;z-index:3;top:160px;left:180px;">
<img style="cursor:pointer; " src="{:U(&#39;Verify&#39;)}" onclick="this.src=this.src+&#39;?&#39;+Math.random()" id="safecode" style="height:50px;width:70%;"/>
</p> 
//验证码判断
public function Verify(){
ob_clean();
//显示验证码
$cfg=array(
&#39;codeSet&#39; => &#39;0123456789&#39;, // 验证码字符集合
&#39;imageH&#39; => 25, // 验证码图片高度
&#39;imageW&#39; => 80, // 验证码图片宽度
&#39;length&#39; => 4, // 验证码位数
&#39;fontttf&#39; => &#39;4.ttf&#39;, // 验证码字体,不设置随机获取
&#39;fontSize&#39; => 10, // 验证码字体大小(px)
&#39;useNoise&#39; => false, // 是否添加杂点
&#39;useCurve&#39; => false, // 是否画混淆曲线
&#39;bg&#39; => array(226,229,236) //背景颜色
);
$very=new \Think\Verify($cfg);
$very->entry();
} 
//客户端通过ajax,实现校验验证码
public function checkVerify(){
$code = I(&#39;get.code&#39;);
$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[&#39;verify_code&#39;]) {
echo json_encode(array(&#39;flag&#39;=>1,&#39;cont&#39;=>&#39;验证码正确&#39;));
}else{
echo json_encode(array(&#39;flag&#39;=>2,&#39;cont&#39;=>&#39;验证码错误&#39;));
}
}
private function auth_my_code($vry,$str){
$key = substr(md5($vry->seKey), 5, 8);
$str = substr(md5($str), 8, 10);
return md5($key . $str);
}
Si le code de vérification ci-dessus est mal saisi et ne peut pas être automatiquement actualisé après la soumission, après avoir modifié le code :


location.href="/Login/Login" ; Cela ne fonctionnera que sur toute la page Actualiser et soumettre les valeurs du formulaire peuvent être perdues, ce qui affecte grandement l'expérience utilisateur.


2. Si le code de vérification est mal saisi, le code de vérification sera automatiquement actualisé après la soumission.

else{
$(&#39;#safecode&#39;).attr("src","/Login/Verify?"+Math.random());
NewAlert(2,"验证码有误,请重新输入",null);
code_ok = false;
$(&#39;#verifyresult&#39;).html(msg.cont).css({&#39;color&#39;:&#39;red&#39;,&#39;font-size&#39;:&#39;12px&#39;}); 
}

3. Ce qui suit est la soumission ajax du code de vérification à la vérification des antécédents :

Recommandations associées :


Le framework thinkPHP implémente la méthode de génération de codes-barres

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn