找回密码
 立即注册

QQ登录

只需一步,快速开始

查看: 901|回复: 0
打印 上一主题 下一主题

thinkphp3.2点击刷新生成验证码

[复制链接]

2617

主题

2617

帖子

7789

积分

论坛元老

Rank: 8Rank: 8

积分
7789
跳转到指定楼层
楼主
发表于 2018-2-14 05:38:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式

            再介绍thinkphp3.2验证码的使用方法之前,先为大家详细介绍ThinkPHP 验证码,具体内容如下
ThinkPHP 内置了验证码的支持,可以直接使用。要使用验证码,需要导入扩展类库中的 ORG.Util.Image 类库和 ORG.Util.String 类库。
验证码方法
我们通过在在模块类中增加一个 verify 方法来用于显示验证码,最简单的例子:
Public function verify(){
  // 导入Image类库
  import("ORG.Util.Image");
  Image::buildImageVerify();
}
import 方法是 ThinkPHP 内置的类库和文件导入方法,上例导入的文件为 ThinkPHP 系统目录下 Lib/ORG/Util/Image.class.php 文件。如果已经将 Image 类库拷贝到了当前项目下,如 Lib/ORG 下,则可以以:
import("@.Util.Image");
import 方法是 ThinkPHP 内置的类库和文件导入方法,上例导入的文件为 ThinkPHP 系统目录下 Lib/ORG/Util/Image.class.php 文件。
访问验证码
可以直接在浏览器里访问该验证码方法以确定验证码是否能正常显示:
http://127.0.0.1/index.php/Public/verify
如果一切正常,显示验证码如下所示:

表单中使用验证码
在表单页面中使用验证码,是以 html img标签 来调用:


src 属性值即为验证码方法访问地址,视实际情况不同而不同。
验证码刷新
当点击验证码图片时,触发 JavaScript changeVerify() 函数重新读取验证码,从而实现验证码刷新。该函数参考如下:
验证码验证
在调用验证码 verify 的时候,buildImageVerify 会记录本次验证码的 MD5 信息。在表单验证操作里,以如下方法来检查验证码是否正确:
if($_SESSION['verify'] != md5($_POST['verify'])) {
  $this->error('验证码错误!');
}
其中 $_SESSION['verify'] 中的 verify 名称为 buildImageVerify 方法默认 SESSION 注册名称,具体见 buildImageVerify 语法。
上面例子演示了最简单的 ThinkPHP 验证码的使用方法。上面的例子验证码是 4 位数字,如果想使用更多风格的验证码以及中文验证码,参见本节其余部分内容:《ThinkPHP 使用不同风格及中文的验证码》。
验证码不显示原因
如下发现无法显示验证码,可能的原因如下:
1、PHP 是否已经安装 GD 库支持。
2、输出之前是否有任何的输出(尤其是 UTF8 的 BOM 头信息输出)。
3、Image 类库是否正确导入。
4、如果是表单页面,请查看是否正确调用了验证码显示方法。
下面就为大家介绍 thinkphp3.2 验证码生成和点击刷新验证码的实现方法,具体内容如下
一、实例化生成验证码的类(该方法放到IndexController里面便于访问)

/**
*
* 验证码生成
*/
public function verify_c(){
  $Verify = new \Think\Verify();
  $Verify->fontSize = 18;
  $Verify->length  = 4;
  $Verify->useNoise = false;
  $Verify->codeSet = '0123456789';
  $Verify->imageW = 130;
  $Verify->imageH = 50;
  //$Verify->expire = 600;
  $Verify->entry();
}
二、前台需要生成验证码的图片src属性指向

         

{:U('Home/Index/verify_c',array())}


三、写完上面的后,页面初始化的验证码就可以出现了,下面要写的就是点击验证码图片后,刷新出新的验证码图片(通过jquery修改图片的src属性来完成,请求的处理函数一样,只是在请求后加一个随机数,区别上一张图片的请求)
// 验证码生成
var captcha_$('#captcha-container').find('img')
var verify("src");
captcha_('title', '点击刷新');
captcha_(function(){
  if( verify('?')>0){
    $(this).attr("src", verifyimg+'&random='+Math.random());
  }else{
    $(this).attr("src", verify(/\?.*$/,'')+'?'+Math.random());
  }
});
四、校验验证码输入是否正确
a.在common目录下的function.php里加入全局函数
/**
* 验证码检查
*/
function check_verify($code, $id = ""){
  $verify = new \Think\Verify();
  return $verify->check($code, $id);
}
b.在表单提交的controller对应的处理方法里添加检查代码
// 检查验证码
$verify = I('param.verify','');
if(!check_verify($verify)){
  $this->error("亲,验证码输错了哦!",$this->site_url,9);
}
到此tp3.2验证码的使用就可以了。
补充:我在写的时候将四的b步骤放到一个ajax里验证,返回一次检验结果。然后再依据返回结果确定是否要提交表单,但是在验证码通过第一次的校验后,第二次的就不可以了,目前还没想明白原因。
这就是本文的全部内容,文章最后还有一个小小的疑问,希望大家可以想出解决办法,也希望本文对大家的学习有所帮助。
            
            
您可能感兴趣的文章:
  • ThinkPHP登录功能的实现方法
  • ThinkPHP实现带验证码的文件上传功能实例
  • 完美解决thinkphp验证码出错无法显示的方法
  • thinkPHP中验证码的简单使用方法
  • ThinkPHP3.2.2实现持久登录(记住我)功能的方法
  • thinkphp验证码的实现(form、ajax实现验证)
  • thinkPHP中验证码的简单实现方法
  • 详解ThinkPHP3.2.3验证码显示、刷新、校验
  • Thinkphp3.2实用篇之计算型验证码示例
  • ThinkPHP实现登录退出功能
  • thinkPHP5项目中实现QQ第三方登录功能
  • thinkPHP实现的验证码登录功能示例
            
  • 分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
    收藏收藏
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    用户反馈
    客户端