thinkphp3.2 代码生成并点击验证码

时间:2023-03-09 22:08:35
thinkphp3.2 代码生成并点击验证码

本人小菜鸟一仅仅。为了自我学习和交流PHP(jquery,linux,lamp,shell,javascript,server)等一系列的知识。小菜鸟创建了一个群。希望光临本博客的人能够进来交流。寻求共同发展。搭建平台。

本人博客也有很多的技术文档,希望能够为你提供一些帮助。



QQ群:   191848169               QQ:450225664



背景:之前说的自己做的项目。偷懒登录模块没加验证码,想了想还是加上,找了下tp的文档,发现是有整合进去的,特记录下。

一、实例化生成验证码的类(该方法放到IndexController里面便于訪问)

  1. /** 
  2.  *  
  3.  * 验证码生成 
  4.  */  
  5. public function verify_c(){  
  6.     $Verify = new \Think\Verify();  
  7.     $Verify->fontSize = 18;  
  8.     $Verify->length   = 4;  
  9.     $Verify->useNoise = false;  
  10.     $Verify->codeSet = '0123456789';  
  11.     $Verify->imageW = 130;  
  12.     $Verify->imageH = 50;  
  13.     //$Verify->expire = 600;  
  14.     $Verify->entry();  
  15. }  

二、前台须要生成验证码的图片src属性指向

  1. <p class="top15 captcha" id="captcha-container">  
  2.   <input name="verify" width="50%" height="50" class="captcha-text" placeholder="验证码" type="text">                  
  3.   <img width="30%" class="left15" height="50" alt="验证码" src="{:U('Home/Index/verify_c',array())}" title="点击刷新">  
  4. </p>  

三、写完上面的后,页面初始化的验证码就能够出现了,以下要写的就是点击验证码图片后,刷新出新的验证码图片(通过jquery改动图片的src属性来完毕,请求的处理函数一样。仅仅是在请求后加一个随机数,差别上一张图片的请求)

  1. // 验证码生成  
  2. var captcha_img = $('#captcha-container').find('img')  
  3. var verifyimg = captcha_img.attr("src");  
  4. captcha_img.attr('title', '点击刷新');  
  5. captcha_img.click(function(){  
  6.     if( verifyimg.indexOf('?

    ')>0){  

  7.         $(this).attr("src", verifyimg+'&random='+Math.random());  
  8.     }else{  
  9.         $(this).attr("src", verifyimg.replace(/\?

    .*$/,'')+'?'+Math.random());  

  10.     }  
  11. });  

四、校验验证码输入是否正确

a.在common文件夹下的function.php里增加全局函数

  1. /** 
  2.  * 验证码检查 
  3.  */  
  4. function check_verify($code, $id = ""){  
  5.     $verify = new \Think\Verify();  
  6.     return $verify->check($code, $id);  
  7. }  

b.在表单提交的controller相应的处理方法里加入检查代码

  1. // 检查验证码  
  2. $verify = I('param.verify','');  
  3. if(!check_verify($verify)){  
  4.     $this->error("亲,验证码输错了哦!",$this->site_url,9);  
  5. }  

到此tp3.2验证码的使用就能够了。

补充:我在写的时候将四的b步骤放到一个ajax里验证,返回一次检验结果。然后再根据返回结果确定是否要提交表单,可是在验证码通过第一次的校验后。第二次它不能够做到这一点,现在不想要一个明确的原因。

版权声明:本文博客原创文章,博客,未经同意,不得转载。