首页 > 作文

PHP+jQuery 注册模块的改进(一):验证码存入SESSION

更新时间:2023-04-06 21:15:20 阅读: 评论:0

需要修改的几个文件:

①register.php 生成随机数和加密值

把register.html改为register.php,并开启ssion;

把register.js中生成随机数的函数写在register.php中,并改用php方法

<?php ssion_start();?>....<?php         //生成随机数函数  function showval(){    $num = "";    for($i=0;$i<4;$i++){      $tmp = rand(1,15);      if ($tmp > 9) {        switch ($tmp) {          ca(10):            $num .= 'a';            break;          ca(11):            $num .= 'b';            break;          ca(12):            $num .= 'c';            break;          ca(13):            $num .= 'd';            break;          ca(14):            $num .= 'e';            break;          ca(15):            $num .= 'f';            break;          }        } el {          $num .= $tmp;          }          }      return $num;    }    //生成随机数  $mdnum = md5(showval());    //把随机数和经过加密的随机数都存入ssion  $_ssion['num'] = showval();  $_ssion['mdnum'] = $mdnum;  ?>  <!--验证码-->  <div class="ipt iptend">    <input type='text' id='yzm' name='yzm' placeholder="验证码" autocomplete="off" />    <img id='yzmpic' src='valcode.php?num=<?php echo $mdnum;?>' style="cursor:pointer" title="验证码" alt="验证码">    <a style="cursor:pointer" id='changea'>      <img id="refpic" src="templets/images/ref.jpg" alt="刷新验证码">    </a>    <span id='yzmchk'></span>  </div>

把生成的4位验证码和经过md5加密的验证码都存入ssion,而客户端验证码图片的src属性的参数则是那个加密过的值,因此在客户端不会出现四位验证码的文字。

②valcode.php 把随机数写入图形

在register.php中,验证码图片的地址是

<img id='yzmpic' src='valcode.php?num=<?php echo $mdnum;?>' >

因此在valcode.php中,需要做相应修改,修改之处是把原来的:

//直接传送客户端输入的值$num = $_get['num'];

修改为:

ssion_start();header("content-type:image/png");  //ssion中保存生成的4位随机数和经过ms5加密的随机数  if(ist($_ssion['mdnum']) && $_ssion['mdnum']!=""){      $mdnum = $_ssion['mdnum'];        if(ist($_get['num']) && $_get['num']!=""){        //当注册页传递过来的num和ssion中经过加密的随机数相等时      if($_get['num'] == $mdnum){              if(ist($_ssion['num']) && $_ssion['num']!="")          //把ssion中保存的4位随机数赋给$num          $num = $_ssion['num'];      }    }}

即客户端图片传递过来的加密的参数同ssion中保存的加密过的值相同时,就把ssion中保存的4位验证码写入图形。

valcode.php的完整代码为:

<?php   ssion_start();  header("content-type:image/png");  //ssion中保存生成的4位随机数和经过ms5加密的随机数  if(ist($_ssion['mdnum']) && $_ssion['mdnum']!=""){      $mdnum = $_ssion['mdnum'];        if(ist($_get['num']) && $_get['num']!=""){        //当注册页传递过来的num和ssion中经过加密的随机数相等时      if($_get['num'] == $mdnum){              if(ist($_ssion['num']) && $_s我做了一项小实验作文300字sion['num']!="")          //把ssion中保存的4位随机数赋给$num          $num = $_ssion['num'];      }    }  }  $imagewidth = 150;  $imageheight = 54;    //创建图像  $numimage = imagecreate($imagewidth, $imageheight);    //为图像分配颜色  imagecolorallocate($numimage, 240,240,240);   //字体大小  $font_size = 33;    //字体名称  $fontname = 'arial.ttf';    //循环生成图片文字  for($i = 0;$i<strlen($num);$i++){        //获取文字左上角x坐标    $x = mt_rand(20,20) + $imagewidth*$i/5;        //获取文字左上角y坐标    $y = mt_rand(40, $imageheight);        //为文字分配颜色    $color = imagecolorallocate($numimage, mt_rand(0,150), mt_rand(0,150), mt_rand(0,150));        //写入文字    imagettftext($numimage,$font_size,0,$x,$y,$color,$fontname,$num[$i]);  }    //生成干扰码  for($i = 0;$i<2200;$i++){    $randcolor = imagecolorallocate($numimage, rand(200,255), rand(200,255), rand(200,255));    imagetpixel($numimage, rand()%180, rand()%90, $randcolor);  }    //输出图片  imagepng($numimage);  imagedestroy($numimage);?>

③register.js进行验证

验证部分改为使用ajax进行验证,把输入的4位验证码传递给chkyzm.php文件,和ssion中保存的4位验证码进行对比。

刷新图片时,重新生成4位验证码,并和加密验证码一起写入ssion。重新生成验证码的代码写在了refresh.php中,并在register.js中使用ajax来请求重新生产的4位验证码和加密验证码,并通过jquery把加密验证码的值作为图片的src属性的参数,经过参数和ssion比对后valcode.php会重新生成4位验证码的图片

register.js验证码部分的代码为:

//验证码按钮$("#refpic").hover(function(){          $(this).attr("src","templets/images/refhover.jpg");    },function(){          $(this).attr("src","templets/images/ref.jpg");    }).moudown(function(){          $(this).attr("src","templets/images/refclick.jpg");    }).mouup(function(){          $(this).attr("src","templets/images/ref.jpg");    });        //刷新验证码    function postyzm(){          $.post("./../refresh.php",function(data,textstatus){              $('#yzmpic').attr("src","valcode.php?num="+data);      }近代诗)    }    $('#yzmpic').click(function(){          postyzm();    });     $('#changea').click(function(){          postyzm();中国姓氏起源    });    //验证码检验    function yzmchk(){              $.post("./../chkyzm.php",{                    //要传递的数据        yzm : $("#yzm").val()      },function(data,textstatus){                if(data == 0){                  success($("#yzmchk"),"");          yzmval = true;        }el if(data == 1){                  var noticemsg = '验证码不能为空';          notice($("#yzmchk"),noticemsg);        }el{                  var errormsg = '请输入正确的验证码';          error($("#yzmchk"),errormsg);        }      });          }    //验证码的blur事件    $("#yzm").focus(function(){          var noticemsg = '不区分大小写';      notice($("#yzmchk"),noticemsg);    }).click(funct幼儿园大班教案ion(){          var noticemsg = '不区分大小写';      notice($("yzmdchk"),noticemsg什么是万圣节);    }).keydown(function(){            if(event.keycode == 13){                        //检验        yzmchk();      }    }).keyup(function(){          if(event.keycode == 13){                        //提交        formsub();      }    }).blur(function(){          yzmchk();});

chkyzm.php

<?phpssion_start();header("chart=utf-8");if(ist($_post['yzm']) && $_post['yzm']!=""){  $yzm = $_post['yzm'];  if(ist($_ssion['num']) && $_ssion['num']!=""){    //当输入的验证码和ssion里保存的num一致时    if(strtolower($yzm) == $_ssion['num']){          //输入正确      $state = 0;    }el{          //输入错误      $state = 2;    }  }}el{      //没有输入  $state = 1;}echo $state;?>

refresh.php

<?php ssion_start();//生成验证码function showval(){  $num = "";  for($i=0;$i<4;$i++){    $tmp = rand(1,15);    if ($tmp > 9) {      switch ($tmp) {        ca(10):          $num .= 'a';          break;        ca(11):          $num .= 'b';          break;        ca(12):          $num .= 'c';          break;        ca(13):          $num .= 'd';          break;        ca(14):          $num .= 'e';          break;        ca(15):          $num .= 'f';          break;      }    } el {      $num .= $tmp;    }    }  return $num;}$_ssion['num'] = showval();$_ssion['mdnum'] = md5(showval());echo $_ssion['mdnum'];

显示的效果如图:

总结:

5个步骤:把4位验证码写入ssion再生成图片,客户端图片的参数使用加密的验证码,把输入的字符同ssion中的4位验证码进行比对,刷新图片重新生成4位验证码并存入ssion,把重新生产的加密验证码作为图片的src参数

用图可表示为:

(未完待续)

本文发布于:2023-04-06 21:15:19,感谢您对本站的认可!

本文链接:https://www.wtabcd.cn/fanwen/zuowen/10987a012694f623524d13c0abb444a3.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

本文word下载地址:PHP+jQuery 注册模块的改进(一):验证码存入SESSION.doc

本文 PDF 下载地址:PHP+jQuery 注册模块的改进(一):验证码存入SESSION.pdf

标签:验证码   随机数   图片   参数
相关文章
留言与评论(共有 0 条评论)
   
验证码:
Copyright ©2019-2022 Comsenz Inc.Powered by © 专利检索| 网站地图