zoukankan      html  css  js  c++  java
  • tp3.2 的验证码的使用

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

    1. /** 
    2.  *  
    3.  * 验证码生成 
    4.  */  
    5. public function verify_c(){  
    6.     $Verify = new ThinkVerify();  
    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. <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 ThinkVerify();  
    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. }  
  • 相关阅读:
    SQL JOB
    Log4net配置
    教你怎么使用Windows7系统自带的备份与还原的方法
    在LINQ TO SQL 中使用MVC3中的DataAnnotations 【MetadataType】
    图片下载
    DOS的一些常用命令
    自动合并多个文件如js css等 可以增加效率
    利用$.getJSON() 跨域请求操作
    在razor中使用递归,巧用递归
    Use ASP.NET and DotNetZip to Create and Extract ZIP Files
  • 原文地址:https://www.cnblogs.com/qjyking/p/5363725.html
Copyright © 2011-2022 走看看