四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

PHP+jQuery 注冊(cè)模塊的改進(jìn)(一):驗(yàn)證碼存入SESSION

需要修改的幾個(gè)文件:

①register.php 生成隨機(jī)數(shù)和加密值

把register.html改為register.php,并開(kāi)啟session;

把register.js中生成隨機(jī)數(shù)的函數(shù)寫(xiě)在register.php中,并改用php方法

<?php session_start();?>....<?php         //生成隨機(jī)數(shù)函數(shù)  function showval(){    $num = "";    for($i=0;$i<4;$i++){      $tmp = rand(1,15);      if ($tmp > 9) {        switch ($tmp) {          case(10):            $num .= 'a';            break;          case(11):            $num .= 'b';            break;          case(12):            $num .= 'c';            break;          case(13):            $num .= 'd';            break;          case(14):            $num .= 'e';            break;          case(15):            $num .= 'f';            break;          }        } else {          $num .= $tmp;          }          }      return $num;    }    //生成隨機(jī)數(shù)  $mdnum = md5(showval());    //把隨機(jī)數(shù)和經(jīng)過(guò)加密的隨機(jī)數(shù)都存入session  $_SESSION['num'] = showval();  $_SESSION['mdnum'] = $mdnum;  ?>  <!--驗(yàn)證碼-->  <div class="ipt iptend">    <input type='text' id='yzm' name='yzm' placeholder="驗(yàn)證碼" autocomplete="off" />    <img id='yzmpic' src='valcode.php?num=<?php echo $mdnum;?>' style="cursor:pointer" title="驗(yàn)證碼" alt="驗(yàn)證碼">    <a style="cursor:pointer" id='changea'>      <img id="refpic" src="templets/images/ref.jpg" alt="刷新驗(yàn)證碼">    </a>    <span id='yzmchk'></span>  </div>

把生成的4位驗(yàn)證碼和經(jīng)過(guò)md5加密的驗(yàn)證碼都存入session,而客戶端驗(yàn)證碼圖片的src屬性的參數(shù)則是那個(gè)加密過(guò)的值,因此在客戶端不會(huì)出現(xiàn)四位驗(yàn)證碼的文字。

②valcode.php 把隨機(jī)數(shù)寫(xiě)入圖形

在register.php中,驗(yàn)證碼圖片的地址是

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

因此在valcode.php中,需要做相應(yīng)修改,修改之處是把原來(lái)的:

//直接傳送客戶端輸入的值$num = $_GET['num'];

修改為:

session_start();header("content-type:image/png");  //session中保存生成的4位隨機(jī)數(shù)和經(jīng)過(guò)ms5加密的隨機(jī)數(shù)  if(isset($_SESSION['mdnum']) && $_SESSION['mdnum']!=""){      $mdnum = $_SESSION['mdnum'];        if(isset($_GET['num']) && $_GET['num']!=""){        //當(dāng)注冊(cè)頁(yè)傳遞過(guò)來(lái)的num和session中經(jīng)過(guò)加密的隨機(jī)數(shù)相等時(shí)      if($_GET['num'] == $mdnum){              if(isset($_SESSION['num']) && $_SESSION['num']!="")          //把session中保存的4位隨機(jī)數(shù)賦給$num          $num = $_SESSION['num'];      }    }}

即客戶端圖片傳遞過(guò)來(lái)的加密的參數(shù)同session中保存的加密過(guò)的值相同時(shí),就把session中保存的4位驗(yàn)證碼寫(xiě)入圖形。

valcode.php的完整代碼為:

<?php   session_start();  header("content-type:image/png");  //session中保存生成的4位隨機(jī)數(shù)和經(jīng)過(guò)ms5加密的隨機(jī)數(shù)  if(isset($_SESSION['mdnum']) && $_SESSION['mdnum']!=""){      $mdnum = $_SESSION['mdnum'];        if(isset($_GET['num']) && $_GET['num']!=""){        //當(dāng)注冊(cè)頁(yè)傳遞過(guò)來(lái)的num和session中經(jīng)過(guò)加密的隨機(jī)數(shù)相等時(shí)      if($_GET['num'] == $mdnum){              if(isset($_SESSION['num']) && $_SESSION['num']!="")          //把session中保存的4位隨機(jī)數(shù)賦給$num          $num = $_SESSION['num'];      }    }  }  $imagewidth = 150;  $imageheight = 54;    //創(chuàng)建圖像  $numimage = imagecreate($imagewidth, $imageheight);    //為圖像分配顏色  imagecolorallocate($numimage, 240,240,240);   //字體大小  $font_size = 33;    //字體名稱(chēng)  $fontname = 'arial.ttf';    //循環(huán)生成圖片文字  for($i = 0;$i<strlen($num);$i++){        //獲取文字左上角x坐標(biāo)    $x = mt_rand(20,20) + $imagewidth*$i/5;        //獲取文字左上角y坐標(biāo)    $y = mt_rand(40, $imageheight);        //為文字分配顏色    $color = imagecolorallocate($numimage, mt_rand(0,150), mt_rand(0,150), mt_rand(0,150));        //寫(xiě)入文字    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));    imagesetpixel($numimage, rand()%180, rand()%90, $randcolor);  }    //輸出圖片  imagepng($numimage);  imagedestroy($numimage);?>

③register.js進(jìn)行驗(yàn)證

驗(yàn)證部分改為使用Ajax進(jìn)行驗(yàn)證,把輸入的4位驗(yàn)證碼傳遞給chkyzm.php文件,和session中保存的4位驗(yàn)證碼進(jìn)行對(duì)比。

刷新圖片時(shí),重新生成4位驗(yàn)證碼,并和加密驗(yàn)證碼一起寫(xiě)入session。重新生成驗(yàn)證碼的代碼寫(xiě)在了refresh.php中,并在register.js中使用ajax來(lái)請(qǐng)求重新生產(chǎn)的4位驗(yàn)證碼和加密驗(yàn)證碼,并通過(guò)jQuery把加密驗(yàn)證碼的值作為圖片的src屬性的參數(shù),經(jīng)過(guò)參數(shù)和session比對(duì)后valcode.php會(huì)重新生成4位驗(yàn)證碼的圖片

register.js驗(yàn)證碼部分的代碼為:

//驗(yàn)證碼按鈕$("#refpic").hover(function(){          $(this).attr("src","templets/images/refhover.jpg");    },function(){          $(this).attr("src","templets/images/ref.jpg");    }).mousedown(function(){          $(this).attr("src","templets/images/refclick.jpg");    }).mouseup(function(){          $(this).attr("src","templets/images/ref.jpg");    });        //刷新驗(yàn)證碼    function postyzm(){          $.post("./../refresh.php",function(data,textStatus){              $('#yzmpic').attr("src","valcode.php?num="+data);      })    }    $('#yzmpic').click(function(){          postyzm();    });     $('#changea').click(function(){          postyzm();    });    //驗(yàn)證碼檢驗(yàn)    function yzmchk(){              $.post("./../chkyzm.php",{                    //要傳遞的數(shù)據(jù)        yzm : $("#yzm").val()      },function(data,textStatus){                if(data == 0){                  success($("#yzmchk"),"");          yzmval = true;        }else if(data == 1){                  var noticeMsg = '驗(yàn)證碼不能為空';          notice($("#yzmchk"),noticeMsg);        }else{                  var errorMsg = '請(qǐng)輸入正確的驗(yàn)證碼';          error($("#yzmchk"),errorMsg);        }      });          }    //驗(yàn)證碼的blur事件    $("#yzm").focus(function(){          var noticeMsg = '不區(qū)分大小寫(xiě)';      notice($("#yzmchk"),noticeMsg);    }).click(function(){          var noticeMsg = '不區(qū)分大小寫(xiě)';      notice($("yzmdchk"),noticeMsg);    }).keydown(function(){            if(event.keyCode == 13){                        //檢驗(yàn)        yzmchk();      }    }).keyup(function(){          if(event.keyCode == 13){                        //提交        formsub();      }    }).blur(function(){          yzmchk();});

chkyzm.php

<?phpsession_start();header("charset=utf-8");if(isset($_POST['yzm']) && $_POST['yzm']!=""){  $yzm = $_POST['yzm'];  if(isset($_SESSION['num']) && $_SESSION['num']!=""){    //當(dāng)輸入的驗(yàn)證碼和session里保存的num一致時(shí)    if(strtolower($yzm) == $_SESSION['num']){          //輸入正確      $state = 0;    }else{          //輸入錯(cuò)誤      $state = 2;    }  }}else{      //沒(méi)有輸入  $state = 1;}echo $state;?>

refresh.php

<?php session_start();//生成驗(yàn)證碼function showval(){  $num = "";  for($i=0;$i<4;$i++){    $tmp = rand(1,15);    if ($tmp > 9) {      switch ($tmp) {        case(10):          $num .= 'a';          break;        case(11):          $num .= 'b';          break;        case(12):          $num .= 'c';          break;        case(13):          $num .= 'd';          break;        case(14):          $num .= 'e';          break;        case(15):          $num .= 'f';          break;      }    } else {      $num .= $tmp;    }    }  return $num;}$_SESSION['num'] = showval();$_SESSION['mdnum'] = md5(showval());echo $_SESSION['mdnum'];

顯示的效果如圖:

總結(jié):

5個(gè)步驟:把4位驗(yàn)證碼寫(xiě)入session再生成圖片,客戶端圖片的參數(shù)使用加密的驗(yàn)證碼,把輸入的字符同SESSION中的4位驗(yàn)證碼進(jìn)行比對(duì),刷新圖片重新生成4位驗(yàn)證碼并存入session,把重新生產(chǎn)的加密驗(yàn)證碼作為圖片的src參數(shù)

用圖可表示為:

(未完待續(xù))

php技術(shù)PHP+jQuery 注冊(cè)模塊的改進(jìn)(一):驗(yàn)證碼存入SESSION,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 狂野殴美激情性bbbbbb| 哥吉拉| 6套电影频道节目表| hunger game| 吻胸捏胸揉视频大全| 吸痰护理ppt课件| 黄色免费视频| 权志龙壁纸| 我的吸血鬼学姐| 唐砖演员表| 我爱五指山我爱万泉河| jenna haze| 间宫祥太朗| 女子监狱第五季| 镀金时代第三季什么时候播放| 张天爱三级露全乳hd电影| 生死劫杀1946| 电视剧《反击》主要演员| 二年级上册第一单元数学试卷可打印| 洗衣机水满了还在进水维修视频| 双男主动漫 推荐| 无锡电视台| 别说我的眼泪你无所谓吉他谱| 李鸿杰| 性的秘密| 打开双腿扒开打屁股羞辱惩罚视频| 电影《七三一》| 女生宿舍在线观看| 田园个人简历| 草刈正雄| 企鹅头像| 梦想建筑师泰国百合剧| 鬼整人| 抖一音| 福音电影| 废纸板拳击手| 大国医 电视剧| 潜伏电视剧全集30集免费观看| 王渝萱演过的所有影视作品| 洗冤录粤语| 出彩中国人撒贝宁精忠报国15分钟|