PHP+jQuery 註冊模組的改進(一):驗證碼存入SESSION_php執行個體

來源:互聯網
上載者:User

需要修改的幾個檔案:

①register.php 產生隨機數和加密值

把register.html改為register.php,並開啟session;

把register.js中產生隨機數的函數寫在register.php中,並改用php方法

<?php session_start();?>....<?php         //產生隨機數函數  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;    }    //產生隨機數  $mdnum = md5(showval());    //把隨機數和經過加密的隨機數都存入session  $_SESSION['num'] = showval();  $_SESSION['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加密的驗證碼都存入session,而用戶端驗證碼圖片的src屬性的參數則是那個加密過的值,因此在用戶端不會出現四位驗證碼的文字。

②valcode.php 把隨機數寫入圖形

在register.php中,驗證碼圖片的地址是

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

因此在valcode.php中,需要做相應修改,修改之處是把原來的:

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

修改為:

session_start();header("content-type:image/png");  //session中儲存產生的4位隨機數和經過ms5加密的隨機數  if(isset($_SESSION['mdnum']) && $_SESSION['mdnum']!=""){      $mdnum = $_SESSION['mdnum'];        if(isset($_GET['num']) && $_GET['num']!=""){        //當註冊頁傳遞過來的num和session中經過加密的隨機數相等時      if($_GET['num'] == $mdnum){              if(isset($_SESSION['num']) && $_SESSION['num']!="")          //把session中儲存的4位隨機數賦給$num          $num = $_SESSION['num'];      }    }}

即用戶端圖片傳遞過來的加密的參數同session中儲存的加密過的值相同時,就把session中儲存的4位驗證碼寫入圖形。

valcode.php的完整代碼為:

<?php   session_start();  header("content-type:image/png");  //session中儲存產生的4位隨機數和經過ms5加密的隨機數  if(isset($_SESSION['mdnum']) && $_SESSION['mdnum']!=""){      $mdnum = $_SESSION['mdnum'];        if(isset($_GET['num']) && $_GET['num']!=""){        //當註冊頁傳遞過來的num和session中經過加密的隨機數相等時      if($_GET['num'] == $mdnum){              if(isset($_SESSION['num']) && $_SESSION['num']!="")          //把session中儲存的4位隨機數賦給$num          $num = $_SESSION['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));    imagesetpixel($numimage, rand()%180, rand()%90, $randcolor);  }    //輸出圖片  imagepng($numimage);  imagedestroy($numimage);?>

③register.js進行驗證

驗證部分改為使用Ajax進行驗證,把輸入的4位驗證碼傳遞給chkyzm.php檔案,和session中儲存的4位驗證碼進行對比。

重新整理圖片時,重建4位驗證碼,並和加密驗證碼一起寫入session。重建驗證碼的代碼寫在了refresh.php中,並在register.js中使用ajax來請求重新生產的4位驗證碼和加密驗證碼,並通過jQuery把加密驗證碼的值作為圖片的src屬性的參數,經過參數和session比對後valcode.php會重建4位驗證碼的圖片

register.js驗證碼部分的代碼為:

//驗證碼按鈕$("#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");    });        //重新整理驗證碼    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;        }else if(data == 1){                  var noticeMsg = '驗證碼不可為空';          notice($("#yzmchk"),noticeMsg);        }else{                  var errorMsg = '請輸入正確的驗證碼';          error($("#yzmchk"),errorMsg);        }      });          }    //驗證碼的blur事件    $("#yzm").focus(function(){          var noticeMsg = '不區分大小寫';      notice($("#yzmchk"),noticeMsg);    }).click(function(){          var noticeMsg = '不區分大小寫';      notice($("yzmdchk"),noticeMsg);    }).keydown(function(){            if(event.keyCode == 13){                        //檢驗        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']!=""){    //當輸入的驗證碼和session裡儲存的num一致時    if(strtolower($yzm) == $_SESSION['num']){          //輸入正確      $state = 0;    }else{          //輸入錯誤      $state = 2;    }  }}else{      //沒有輸入  $state = 1;}echo $state;?>

refresh.php

<?php session_start();//產生驗證碼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'];

顯示的效果如圖:

總結:

5個步驟:把4位驗證碼寫入session再產生圖片,用戶端圖片的參數使用加密的驗證碼,把輸入的字元同SESSION中的4位驗證碼進行比對,重新整理圖片重建4位驗證碼並存入session,把重新生產的加密驗證碼作為圖片的src參數

用圖可表示為:

(未完待續)

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.