本人小菜鸟一仅仅。为了自我学习和交流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里验证,返回一次检验结果。然后再根据返回结果确定是否要提交表单,可是在验证码通过第一次的校验后。第二次它不能够做到这一点,现在不想要一个明确的原因。

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

thinkphp3.2 代码生成并点击验证码的更多相关文章

  1. clicaptcha中文点击验证码开发经验总结

    现在的验证码真是越来越高级了,12306 的找图验证码,极验的拖动式验证码,还有国外的一些黑科技,能智能判断你是不是机器人的验证码. 验证码的更新迭代让我突然对传统验证码一下子不满足了,出于挑战自我和 ...

  2. 验证码在后台的编写,并实现点击验证码图片时时发生更新 C# 项目发布到IIS后不能用log4net写日志

    验证码在后台的编写,并实现点击验证码图片时时发生更新   验证码在软件中的地位越来越重要,有效防止这种问题对某一个特定注册用户用特定程序暴力破解方式进行不断的登陆尝试:下面就是实现验证码的基本步骤: ...

  3. JS 点击验证码刷新

    <img src="/get_valid_img" id="valid-img" title="点击再换一张" class=" ...

  4. 点击验证码刷新(tp3.1)--超简单

    省略js点击刷新验证码,虽然看不懂 <img src='http://localhost/app/index.php/Index/verify/'  onclick='this.src=this ...

  5. java登录点击验证码图片切换验证码无效

    1.问题:我在写一个登录时需要添加一个验证码的功能,但是第一次可以生成验证码,但是点击的时候无法发起请求. 2.解决方案:在请求地址后面加一个时间戳,保证每次请求都不一样就可以了! window.on ...

  6. Flask 验证码 点击验证码刷新

    ---恢复内容开始--- import random import string # Image:一个画布 # ImageDraw:一个画笔 # ImageFont:画笔的字体 # pip insta ...

  7. yii2.0 点击验证码图片不刷新

    修改vender\yiisoft\yii2\captcha\CaptchaAction下的run方法 public function run(){ if (Yii::$app->request- ...

  8. WPF做12306验证码点击效果

    一.效果 和12306是一样的,运行一张图上点击多个位置,横线以上和左边框还有有边框位置不允许点击,点击按钮输出坐标集合,也就是12306登陆的时候,需要向后台传递的参数. 二.实现思路 1.获取验证 ...

  9. J2EE如何生成验证码图片和点击刷新验证码

    验证码图片生成步骤 创建BufferedImage对象. 获取BufferedImage的画笔,即调用getGraphics()方法获取Graphics对象. 调用Graphics对象的setColo ...

随机推荐

  1. android client随机验证码生成函数

    由于该项目使用验证码.自己找了一些资料.尽量把这个验证码做出来.代码不是很,較的简单,以下给大家看看我是怎么实现该功能的: 源代码地址下载:http://download.csdn.net/detai ...

  2. python学习笔记之六:更加抽象

    Python被称为面向对象的语言,创建自己的对象是python非常核心的概念.这里会介绍如何创建对象,以及多态,封装,方法,特性,超类以及继承的概念. 一. 对象的魔力 面向对象程序设计中的术语 对象 ...

  3. text bss data的区别

    BSS段 在采用段式内存管理的架构中,BSS段(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域.BSS是英文Block Started by Symbol的简称.BSS ...

  4. eclipse 代码清理 代码格式化 代码凝视

    Code Style包含两个方面:代码清理,代码规范化.代码清理能够參考: http://www.ibm.com/developerworks/cn/opensource/os-eclipse-cle ...

  5. 正确Linux新手很实用20命令

     //正确Linux新手很实用20命令 //slwang  2014.4.19 1, ls list directory contents 内容 ls -l     //以详情模式(long li ...

  6. 如何设置多个同一页的tinymce编辑

    的页面设置多个tinymce编辑器 This example shows how to setup multiple editors on the same page and with differe ...

  7. Android在API推荐的方式来实现SQLite数据库的增长、删除、变化、检查操作

    package com.examp.use_SQLite.dao; import java.util.ArrayList; import java.util.List; import android. ...

  8. Hive自己定义函数的使用——useragent解析

    想要从日志数据中分析一下操作系统.浏览器.版本号使用情况.可是hive中的函数不能直接解析useragent,于是能够写一个UDF来解析.useragent用于表示用户的当前操作系统,浏览器版本号信息 ...

  9. HDU 1069 Monkey and Banana(DP 长方体堆放问题)

    Monkey and Banana Problem Description A group of researchers are designing an experiment to test the ...

  10. hdu1506——Largest Rectangle in a Histogram

    Largest Rectangle in a Histogram Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...