zoukankan      html  css  js  c++  java
  • ThinkPhp框架:验证码功能

    一.单个验证码

    1.依旧可以沿用上传功能所新建的控制器TestController.class.php

    2.创建操作方法

    namespace HomeController;
    use ThinkController;
    class TestController extends Controller {
        public function yanzheng(){
    		$this->show();//显示模版页面
    	}
    
    }
     

    3.在Home/View/Test下新建验证的模版页 yanzheng.html 使用ajax来验证

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
    <title>无标题文档</title>
    <script src="__ROOT__/Public/js/jquery-3.2.0.min.js"></script>
    </head>
    
    <body>
    <h1>验证码</h1>
    <img src="__CONTROLLER__/yzm" id="img"/><input type="test" name="yzm" id="txt"/><input type="submit" id="btn" value="验证"/>
    </body>
    <script type="text/javascript">
    //失去焦点时触发事件 $("#btn").click(function(){ var yzm = $("#txt").val();//取到用户输入的值 $.ajax({ url:"__CONTROLLER__/yz", data:{yzm:yzm}, type:"POST", dataType:"TEXT", success:function(data){ if(data.trim()=="ok"){ alert("成功"); }else{ alert("失败"); } } }); }) $("#img").click(function(){ var sjs = Math.floor(Math.random() *100); $(this).attr("src","__CONTROLLER__/yzm/code/"+sjs); }) </script> </html>

    4.建一个操作方法yzm用来生成验证码 并且 让验证按钮指向一个操作方法,新建一个yz操作方法

    <?php
    namespace HomeController;
    use ThinkController;
    class TestController extends Controller {
          public function yanzheng(){
    		$this->show();//显示模版页面
    	}
    	public function yzm(){
    		$v = new ThinkVerify();//造对象
    		//$v->useImgBg = true;//是否使用背景图片 默认为false
    		//$v->fontSize="30";//验证码字体大小(像素) 默认为25
    		//$v->useCurve=false;//是否使用混淆曲线 默认为true
    		//$v->useNoise=false;//是否添加杂点 默认为true
    		//$v->length="4";//验证码位数
    		$v->useZh = true;//中文验证码
    		$v->fontttf="STKAITI.TTF";
    		$v->entry();//生成验证码
    	}
    	public function yz(){
    		$yzm = $_POST["yzm"];
    		$v = new ThinkVerify();
    		if($v->check($yzm)){//验证
    			$this->ajaxReturn("ok","eval");
    		}else{
    			$this->ajaxReturn("no","eval");
    		}
    	}          
    
    }    
    

    实现的效果如下:

       

    输入文字后点击验证:

    二.两个验证码

    1.给模版加一个img标签

    <body>
    <h1>验证码</h1>
    <img src="__CONTROLLER__/yzm" id="img"/><input type="test" name="yzm" id="txt"/><input type="submit" id="btn" value="验证"/>
    <img src="__CONTROLLER__/yzm2" id="img2"/>
    </body>
    

     2.控制器的方法也要写个yzm方法,叫做yzm2,如果有两个验证码,entry就要进行标识,entry(1)entry( 2)

    public function yanzheng(){
    		$this->show();//显示模版页面
    	}
    	public function yzm(){
    		$v = new ThinkVerify();//造对象
    		//$v->useImgBg = true;//是否使用背景图片 默认为false
    		//$v->fontSize="30";//验证码字体大小(像素) 默认为25
    		//$v->useCurve=false;//是否使用混淆曲线 默认为true
    		//$v->useNoise=false;//是否添加杂点 默认为true
    		//$v->length="4";//验证码位数
    		$v->useZh = true;//中文验证码
    		$v->fontttf="STKAITI.TTF";
    		$v->entry(1);//生成验证码
    	}
    	public function yz(){
    		$yzm = $_POST["yzm"];
    		$v = new ThinkVerify();
    		if($v->check($yzm,1)){//验证
    			$this->ajaxReturn("ok","eval");
    		}else{
    			$this->ajaxReturn("no","eval");
    		}
    	}
    	public function yzm2(){
    		$v = new ThinkVerify();
    		$v->entry(2);//生成验证码
    	}
    

     3.然后在check方法中写入一个标识,就是要验证哪一个的标识,这里验证是第一个

    public function yz(){
    		$yzm = $_POST["yzm"];
    		$v = new ThinkVerify();
    		if($v->check($yzm,1)){//验证
    			$this->ajaxReturn("ok","eval");
    		}else{
    			$this->ajaxReturn("no","eval");
    		}
    	}
    

     显示的结果:

    注意:有时候浏览器不同也会有bug,比如IE浏览器就不刷新,所以我们要加一个东西,让它适应任何的浏览器,可以这样写

    $("#img").click(function(){
    	var sjs = Math.floor(Math.random() *100);//生成随机数
    	$(this).attr("src","__CONTROLLER__/yzm/code/"+sjs);//拼接上截取后的随机数
    })
    

     三.验证码参数

    注意:参数的设置有两种方法

    一是实例化传入参数:

    $config = array(   
        'fontSize'    =>    30,    // 验证码字体大小   
        'length'      =>    3,     // 验证码位数   
        'useNoise'    =>    false, // 关闭验证码杂点
    );
    $Verify = new ThinkVerify($config);
    $Verify->entry();
    

     二是动态设置:

    $Verify = new ThinkVerify();
    $Verify->fontSize = 30;
    $Verify->length   = 3;
    $Verify->useNoise = false;
    $Verify->entry();
    

     强调一下中文验证码的方法1.本身框架里没有字体参数,所以从C盘找到字体参数

    2.选取ttf格式的字体参数复制到thinkphpThinkPHPLibraryThinkVerifyzhttfs文件夹下

    3.代码中调用中文验证码参数

    public function yzm(){
          $v = new ThinkVerify();//造对象
          $v->useZh = true;//中文验证码
          $v->fontttf="STKAITI.TTF";
          $v->entry(1);//生成验证码
    }
    

     

  • 相关阅读:
    VS2008 SP1 安装时异常处理
    Android和iOS自带的人脸检测API
    FAAST 0.08 动作列表
    C#日期格式化(转)
    希望看这篇文章的人,耐心的看完这个短片
    C#实现转换十六进制
    App Store生存法则:iOS开发者经验分享
    开始的关键不是什么时候开始 而是开始后的坚持
    Eclipse IDE
    最近需要看的网站
  • 原文地址:https://www.cnblogs.com/zhaohui123/p/7146152.html
Copyright © 2011-2022 走看看