thinkphp自带验证码

前端页面:

  1. <div style="position:absolute;z-index:3;top:160px;left:180px;">
  2. <img style="cursor:pointer; " src="{:U('Verify')}" onclick="this.src=this.src+'?'+Math.random()" id="safecode" style="height:50px;width:70%;"/>
  3. </div>
  1. //验证码判断
  2. public function Verify(){
  3. ob_clean();
  4. //显示验证码
  5. $cfg=array(
  6. 'codeSet' => '0123456789', // 验证码字符集合
  7. 'imageH' => 25, // 验证码图片高度
  8. 'imageW' => 80, // 验证码图片宽度
  9. 'length' => 4, // 验证码位数
  10. 'fontttf' => '4.ttf', // 验证码字体,不设置随机获取
  11. 'fontSize' => 10, // 验证码字体大小(px)
  12. 'useNoise' => false, // 是否添加杂点
  13. 'useCurve' => false, // 是否画混淆曲线
  14. 'bg' => array(226,229,236) //背景颜色
  15. );
  16. $very=new \Think\Verify($cfg);
  17. $very->entry();
  18. }
  19. //客户端通过ajax,实现校验验证码
  20. public function checkVerify(){
  21. $code = I('get.code');
  22. $very = new \Think\Verify();
  23. $key = $this->auth_my_code($very,$very->seKey);
  24. // 验证码不能为空
  25. $secode = session($key);
  26.  
  27. //对$code进行加密,在比较校验
  28. if($this->auth_my_code($very,strtoupper($code)) == $secode['verify_code']) {
  29. echo json_encode(array('flag'=>1,'cont'=>'验证码正确'));
  30. }else{
  31. echo json_encode(array('flag'=>2,'cont'=>'验证码错误'));
  32. }
  33. }
  34. private function auth_my_code($vry,$str){
  35. $key = substr(md5($vry->seKey), 5, 8);
  36. $str = substr(md5($str), 8, 10);
  37. return md5($key . $str);
  38. }

以上验证码如果输入错误提交后不能自动刷新,对代码进行更改后:

location.href="/Login/Login";这样只能对整个页面刷新,提交表单的值可能会丢失,非常影响用户体验。

2.如果验证码输入错误,提交后自动刷新验证码。

  1. else{
  2. $('#safecode').attr("src","/Login/Verify?"+Math.random());
  3. NewAlert(2,"验证码有误,请重新输入",null);
  4. code_ok = false;
  5. $('#verifyresult').html(msg.cont).css({'color':'red','font-size':'12px'});
  6. }

3.以下为ajax提交验证码到后台校验:

  1. <script type="text/javascript">
  2.  
  3. $("#login_btn").click(function(){
  4. var username = $.trim($("#username").val());
  5. var password = $.trim($("#password").val());
  6. var code = $('#veri').val();
  7. if(username == ""){
  8. NewAlert(2,"请输入用户名",null);
  9. shutdown();
  10. return false;
  11. }else if(password == ""){
  12. NewAlert(2,"请输入密码",null);
  13. shutdown();
  14. return false;
  15. }else if(code==''){
  16. NewAlert(2,"请输入验证码",null);
  17. return false;
  18. }
  19.  
  20. //ajax去服务器端校验
  21. $.ajax({
  22. url:"__CONTROLLER__/checkVerify",
  23. data:{'code':code},
  24. dataType:'json',
  25. success:function(msg){
  26. if(msg.flag==1){
  27. var data= {
  28. username:username,
  29. password:password
  30. };
  31. $.ajax({
  32. type:"POST",
  33. url:"{:U('Login/Login')}",
  34. data:data,
  35. dataType:"json",
  36. success:function(msg){
  37. if(msg.RespCode=='000'){
  38. shutdown();
  39. if(msg.org_code=='fcb'){
  40. location.href="/Invest/index?biao_type=cwb";
  41. }else{
  42. location.href="{$Think.config.VIP_URL}/Individual/index";
  43. }
  44. }else{
  45. NewAlert(2,msg.RespDesc,null);
  46. return false;
  47. }
  48. },
  49. error:function(){
  50. shutdown();
  51. },
  52. beforeSend: function() {
  53. Loading();
  54. },
  55. });
  56. }else{
  57. $('#safecode').attr("src","/Login/Verify?"+Math.random());
  58. NewAlert(2,"验证码有误,请重新输入",null);
  59. code_ok = false;
  60. $('#verifyresult').html(msg.cont).css({'color':'red','font-size':'12px'});
  61. }
  62. }
  63. });
  64. });
  65.  
  66. </script>

thinkphp验证码的更多相关文章

  1. ThinkPHP验证码类

    //ThinkPHP验证码类使用$config = array( 'fontSize' => 30, // 验证码字体大小 'length' => 3, // 验证码位数 'useNois ...

  2. thinkphp验证码(总结之后,效率非常好)

    thinkphp验证码(总结之后,效率非常好) 一.总结 1.总结:总结之后,效率非常好,复习的时候也才方便,也能深入到细处,非常方便建立熟悉感和突破使用困境 2.验证码使用中文集或者繁体集设置:这个 ...

  3. thinkphp验证码不现实多半是bom惹的祸

    thinkphp 验证码不现实多半是bom惹的祸,下面是驱除bom的代码: 链接:https://pan.baidu.com/s/1v5gm7n0L7TGyejCmQrMh2g 提取码:x2p5 免费 ...

  4. ThInkPHP验证码不显示,解决方法汇总

    出现ThInkPHP验证码不显示的情况 官方提示如下:如果无法显示验证码,请检查:① PHP是否已经安装GD库支持:② 输出之前是否有任何的输出(尤其是UTF8的BOM头信息输出):(打开验证码文件为 ...

  5. Thinkphp验证码异步验证第二次及以后验证,验证错误----待解决

    今天进行差错时遇到的问题.别人的回答----链接(http://www.thinkphp.cn/topic/28968.html) 3.2.3版本里的check方法会在第一次验证正确后清除SESSIO ...

  6. thinkphp验证码使用

    在thinkphp中使用验证码很容易,只要调用thinkphp现有的方法就可以.当然,php的GD库肯定是要开的(就是在php.ini中要加载gd模块). thinkphp 3.1 --------- ...

  7. thinkphp 验证码的使用

    在thinkphp中使用验证码很容易,只要调用thinkphp现有的方法就可以.当然,php的GD库肯定是要开的(就是在php.ini中要加载gd模块). thinkphp 3.2 --------- ...

  8. Thinkphp 验证码、文件上传

    一.验证码 验证码参数 例题:登录时验证下验证码 LoginController.class.php <?php namespace Home\Controller; use Think\Con ...

  9. thinkphp验证码的使用

    thinkphp不仅封装了验证规则 还封装了验证码 文件的位置是ThinkPHP\Library\Think\Verify.class.php 下面简单的说一下如何使用 我们现在控制器里新建一个方法 ...

随机推荐

  1. SQL Server 使用全文索引进行页面搜索

    标签:SQL SERVER/MSSQL SERVER/数据库/DBA/全文索引 概述 全文引擎使用全文索引中的信息来编译可快速搜索表中的特定词或词组的全文查询.全文索引将有关重要的词及其位置的信息存储 ...

  2. AngularJs项目文件以及文件夹结构

    app/ ----- Libs/ // references for all libs ---------- angular.js ---------- angular-route.js ----- ...

  3. 为jQuery添加Webkit的触摸方法支持

    前些日子收到邮件,之前兼职的一个项目被转给了其他人,跟进的人来问我相关代码的版权问题. 我就呵呵了. 这段代码是我在做13年一份兼职的时候无聊加上去的,为jQuery添加触摸事件的支持.因为做得有点无 ...

  4. [ASP.NET MVC 小牛之路]18 - Web API

    Web API 是ASP.NET平台新加的一个特性,它可以简单快速地创建Web服务为HTTP客户端提供API.Web API 使用的基础库是和一般的MVC框架一样的,但Web API并不是MVC框架的 ...

  5. fir.im Weekly - 让 iOS 应用更加安全

    攻易防难,关于 iOS 应用安全看起来有些神秘.iOS Security , 源于@吴发伟_则平博客翻译的关于iOS安全的一系列文章,现在站点已经系统收集了大量关于 iOS 逆向.安全.反编译.静动态 ...

  6. 神奇的CSS sprites,制作特效的新方法

    本文主要内容简译自Dava Shea的英文文章 CSS Sprites: Image Slicing’s Kiss of Death,如果觉得博主讲的含糊不清的话,可以看作者原文. 熟悉了常规切图的我 ...

  7. 08. Web大前端时代之:HTML5+CSS3入门系列 ~ QQ空间时间轴

    Web大前端时代之:HTML5+CSS3入门系列:http://www.cnblogs.com/dunitian/p/5121725.html 大前端系列,主要就是使用CSS3.0来实现,注释我已经打 ...

  8. 【Win10应用开发】协议-下篇:自定义多个协议

    前面介绍了如何为应用程序自定义协议,于是有朋友会问,我希望为我的应用注册多个协议,不同的协议处理不同的事情,能吗?答案是能的. 方法主要在配置清单文件上,这里我给出一个例子,示例应用将注册两个协议,分 ...

  9. WPF Excel导出加个手动修改地址

    http://blog.csdn.net/sanjiawan/article/details/6818921 以上是CSDN上的WPF Excel导入导出,我看到有人提问怎么能够手动选择地址,正好用到 ...

  10. IOS数据存储之FMDB数据库

    前言: 最近几天一直在折腾数据库存储,之前文章(http://www.cnblogs.com/whoislcj/p/5485959.html)介绍了Sqlite 数据库,SQLite是一种小型的轻量级 ...