tp框架之验证码

控制器

function yzm()
    {
        /*$config =    array(    
        'fontSize'    =>    30,    // 验证码字体大小    
        'length'      =>    4,     // 验证码位数
        'useImgBg'=>true,
        'useZh'=>true,
        'fontttf'=>'SIMYOU.TTF',
        'zhSet'=>'啊是的分个好就看了'
        
        );*/
        //$v=new     \Think\Verify($config);  //随机自己定义的验证码
        
        $v=new     \Think\Verify();  //使用默认验证码
        $v->entry(1);  //如果你需要在一个页面中生成多个验证码的话,entry方法需要传入可标识的信息,例如:验证码1

    }
    
    function xianshi()
    {
        if(empty($_POST))
        {
            $this->display();
        }
        else
        {
            $yzm=$_POST["yzm"];    
            
            $verify = new \Think\Verify();
            
            var_dump($verify->check($yzm,1));  //1代表第几个验证码
        }    
    }
View Code

显示页面

<!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>
<load href="__PUBLIC__/JS/jquery-1.11.2.min.js" />
</head>

<body>
<form action="__ACTION__" method="post">
<img id="y" src="__CONTROLLER__/yzm" />
<input type="text" name="yzm" />
<input type="submit" value="提交" />
</form>
</body>
<script type="text/javascript">
$(document).ready(function(e) {
    $("#y").click(function(){
        
        var sj=Math.random();  //获取一个随机数
        
        $(this).attr("src","__CONTROLLER__/yzm/c"+sj+"");  //针对ie浏览器,每次都传一个不同的数过去,才能重新加载,别的浏览器不需要
        
        })
});
</script>
</html>
View Code

 

Think\Verify类可以支持验证码的生成和验证功能。

生成验证码

下面是最简单的方式生成验证码:

  1. $Verify = new \Think\Verify();
  2. $Verify->entry();

生成的验证码信息会保存到session中,包含的数据有:

  1. array('verify_code'=>'当前验证码的值','verify_time'=>'验证码生成的时间戳')

如果你需要在一个页面中生成多个验证码的话,entry方法需要传入可标识的信息,例如:验证码1:

  1. // 验证码1
  2. $Verify = new \Think\Verify();
  3. $Verify->entry(1);

验证码2:

  1. // 验证码2
  2. $Verify = new \Think\Verify();
  3. $Verify->entry(2);

验证码参数

可以对生成的验证码设置相关的参数,以达到不同的显示效果。这些参数包括:

参数描述
expire验证码的有效期(秒)
useImgBg是否使用背景图片 默认为false
fontSize验证码字体大小(像素) 默认为25
useCurve是否使用混淆曲线 默认为true
useNoise是否添加杂点 默认为true
imageW验证码宽度 设置为0为自动计算
imageH验证码高度 设置为0为自动计算
length验证码位数
fontttf指定验证码字体 默认为随机获取
useZh是否使用中文验证码
bg验证码背景颜色 rgb数组设置,例如 array(243, 251, 254)
seKey验证码的加密密钥
codeSet验证码字符集合 3.2.1 新增
zhSet验证码字符集合(中文) 3.2.1 新增

参数设置使用两种方式。

实例化传入参数:

  1. $config = array(
  2. 'fontSize' => 30, // 验证码字体大小
  3. 'length' => 3, // 验证码位数
  4. 'useNoise' => false, // 关闭验证码杂点
  5. );
  6. $Verify = new \Think\Verify($config);
  7. $Verify->entry();

或者采用动态设置的方式,如:

  1. $Verify = new \Think\Verify();
  2. $Verify->fontSize = 30;
  3. $Verify->length = 3;
  4. $Verify->useNoise = false;
  5. $Verify->entry();

验证码字体

默认情况下,验证码的字体是随机使用 ThinkPHP/Library/Think/Verify/ttfs/目录下面的字体文件,我们可以指定验证码的字体,例如:

  1. $Verify = new \Think\Verify();
  2. // 验证码字体使用 ThinkPHP/Library/Think/Verify/ttfs/5.ttf
  3. $Verify->fontttf = '5.ttf';
  4. $Verify->entry();

背景图片

支持验证码背景图片功能,可以如下设置:

  1. $Verify = new \Think\Verify();
  2. // 开启验证码背景图片功能 随机使用 ThinkPHP/Library/Think/Verify/bgs 目录下面的图片
  3. $Verify->useImgBg = true;
  4. $Verify->entry();

中文验证码

如果要使用中文验证码,可以设置:

  1. $Verify = new \Think\Verify();
  2. // 验证码字体使用 ThinkPHP/Library/Think/Verify/ttfs/5.ttf
  3. $Verify->useZh = true;
  4. $Verify->entry();

如果无法正常显示,请确认你的 ThinkPHP/Library/Think/Verify/zhttfs/ 目录下面存在中文字体文件。

指定验证码字符

3.2.1版本以上,我们可以指定验证码的字符,通过重新设置codeSet参数即可,例如:

  1. $Verify = new \Think\Verify();
  2. // 设置验证码字符为纯数字
  3. $Verify->codeSet = '0123456789';
  4. $Verify->entry();

如果是中文验证码,可以使用zhSet参数设置,例如:

  1. $Verify = new \Think\Verify();
  2. $Verify->useZh = true;
  3. // 设置验证码字符
  4. $Verify->zhSet = '们以我到他会作时要动国产的一是工就年阶义发成部民可出能方进在了不和有大这';
  5. $Verify->entry();

验证码检测

可以用Think\Verify类的check方法检测验证码的输入是否正确,例如,下面是封装的一个验证码检测的函数:

  1. // 检测输入的验证码是否正确,$code为用户输入的验证码字符串
  2. function check_verify($code, $id = ''){
  3. $verify = new \Think\Verify();
  4. return $verify->check($code, $id);
  5. }

转载于:https://www.cnblogs.com/bilibiliganbei/p/6225346.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
tp框架的request是指在使用tp框架时,通过请求参数来获取用户输入的数据。在tp框架中,可以通过在URL中使用query string的方式传递参数,也可以通过在POST请求中传递参数。引用中的示例URL说明了如何通过URL访问的方式传递请求参数。在这个示例中,请求的URL是localhost/tp5的框架目录/thinkpublic//index.php/index/requests/request,其中包含了一个name参数和一个age参数,分别对应小仓鼠和18。这些参数可以通过tp框架的request对象来获取和处理。 另外,引用中提到,在tp框架的index/controller目录下创建一个名为requests.php的文件,可以用来处理请求,并通过request对象获取请求参数。这样可以更加灵活地处理用户的请求。 最后,引用中提到了一些关于服务器环境和URL重写的配置信息,这些信息不直接与tp框架的request相关,但是可以影响到tp框架的请求处理和参数获取。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [TP5.1:request请求对象(使用四种方式获取)](https://blog.csdn.net/dibeifang3745/article/details/102116291)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [TP6框架全新开发社区系统源码开源下载.zip](https://download.csdn.net/download/qq785557022/85559289)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值