国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > PHP > 正文

PHP驗證碼之Ajax驗證實現方法

2024-05-04 21:58:46
字體:
來源:轉載
供稿:網友

在網站開發中為了提供用戶體驗我們多數都使用ajax來做一些操作,下面我來介紹一個利用ajax實現無刷新頁面的驗證碼ajax驗證有需要的朋友可參考.

下面介紹一個簡單的PHP驗證碼,代碼如下:

  1. <?php   
  2. session_start();  
  3. //設置: 你可以在這里修改驗證碼圖片的參數  
  4. $image_width = 120;  
  5. $image_height = 40;  
  6. $characters_on_image = 6;  
  7. $font = './monofont.ttf';   
  8.    
  9. //以下字符將用于驗證碼中的字符   
  10. //為了避免混淆去掉了數字1和字母i  
  11. $possible_letters = '23456789bcdfghjkmnpqrstvwxyz';  
  12. $random_dots = 10;  
  13. $random_lines = 30;  
  14. $captcha_text_color="0x142864";  
  15. $captcha_noice_color = "0x142864";   
  16.    
  17. $code = '';   
  18.    
  19. $i = 0;  
  20. while ($i < $characters_on_image) {   
  21.     $code .= substr($possible_letters, mt_rand(0, strlen($possible_letters)-1), 1);  
  22.     $i++;  
  23. }  
  24.    
  25. $font_size = $image_height * 0.75;   
  26. $image = @imagecreate($image_width$image_height);  
  27.    
  28. /* 設置背景、文本和干擾的噪點 */  
  29. $background_color = imagecolorallocate($image, 255, 255, 255);  
  30.    
  31. $arr_text_color = hexrgb($captcha_text_color);   
  32. $text_color = imagecolorallocate($image$arr_text_color['red'],   
  33. $arr_text_color['green'], $arr_text_color['blue']);  
  34.    
  35. $arr_noice_color = hexrgb($captcha_noice_color);   
  36. $image_noise_color = imagecolorallocate($image$arr_noice_color['red'],   
  37. $arr_noice_color['green'], $arr_noice_color['blue']);  
  38.    
  39. /* 在背景上隨機的生成干擾噪點 */  
  40. for$i=0; $i<$random_dots$i++ ) {  
  41.     imagefilledellipse($image, mt_rand(0,$image_width),  
  42.     mt_rand(0,$image_height), 2, 3, $image_noise_color);  
  43. }  
  44.    
  45. /* 在背景圖片上,隨機生成線條 */  
  46. for$i=0; $i<$random_lines$i++ ) {  
  47.     imageline($image, mt_rand(0,$image_width), mt_rand(0,$image_height),  
  48.     mt_rand(0,$image_width), mt_rand(0,$image_height), $image_noise_color);  
  49. }  
  50.    
  51. /* 生成一個文本框,然后在里面寫生6個字符 */  
  52. $textbox = imagettfbbox($font_size, 0, $font$code);   
  53. $x = ($image_width - $textbox[4])/2;  
  54. $y = ($image_height - $textbox[5])/2;  
  55. imagettftext($image$font_size, 0, $x$y$text_color$font , $code);  
  56.    
  57. /* 將驗證碼圖片在HTML頁面上顯示出來 */  
  58. header('Content-Type: image/jpeg'); 
  59. // 設定圖片輸出的類型  
  60. imagejpeg($image); 
  61. //顯示圖片  
  62. imagedestroy($image); 
  63. //銷毀圖片實例  
  64. $_SESSION['6_letters_code'] = $code;  
  65. //開源代碼Vevb.com 
  66. function hexrgb ($hexstr) {  
  67.     $int = hexdec($hexstr);  
  68.    
  69.     return array"red" => 0xFF & ($int >> 0x10),  
  70.                 "green" => 0xFF & ($int >> 0x8),  
  71.                 "blue" => 0xFF & $int 
  72.     );  
  73. }  
  74. ?> 

驗證碼生成后,我們要在實際的項目中應用,通常我們使用ajax可以實現點擊驗證碼時刷新生成新的驗證碼(有時生成的驗證碼肉眼很難識別),即“看不清換一張”,填寫驗證碼后,還需要驗證所填驗證碼是否正確,驗證的過程是要后臺程序來完成,但是我們也可以通過ajax來實現無刷新驗證.

驗證驗證碼正確或錯誤的方法

驗證碼圖片上的文字被存放到了SESSION 變量里面,驗證的時候,我們需要將SESSION 里面的值和用戶輸入的值進行比較即可.

$_SESSION[6_letters_code] – 存放著驗證碼的文字值

$_POST[6_letters_code] – 這是用戶輸入的驗證碼的內容

我們建立一個前端頁面index.html,載入jquery,同時在body中加入驗證碼表單元素,代碼如下:

  1. <p>驗證碼:<input type="text" class="input" id="code_num" name="code_num" maxlength="4" />   
  2. <img src="code_num.php" id="getcode_num" title="看不清,點擊換一張" align="absmiddle"></p>  
  3. <p><input type="button" class="btn" id="chk_num" value="提交" /></p> 

html代碼中,<img src="code_num.php"即調用了生成的驗證碼,當點擊驗證碼時,刷新生成新的驗證碼,代碼如下:

  1. $(function(){  
  2.     //數字驗證  
  3.     $("#getcode_num").click(function(){  
  4.         $(this).attr("src",'code_num.php?' + Math.random());  
  5.     });  
  6.     ...  
  7. });  

刷新驗證碼,其實就是重新請求了驗證碼生成程序,這里要注意的是調用code_num.php時要帶上隨機參數防止緩存,接下來填寫好驗證碼之后,點“提交”按鈕,通過$.post(),前端向后臺chk_code.php發送ajax請求,代碼如下:

  1. $(function(){  
  2.     ...  
  3.     $("#chk_num").click(function(){  
  4.         var code_num = $("#code_num").val();  
  5.         $.post("chk_code.php?act=num",{code:code_num},function(msg){  
  6.             if(msg==1){  
  7.                 alert("驗證碼正確!");  
  8.             }else{  
  9.                 alert("驗證碼錯誤!");  
  10.             }  
  11.         });  
  12.     });  
  13. });  

后臺chk_code.php驗證,代碼如下:

  1. session_start();  
  2. $code = trim($_POST['code']);  
  3. if($code==$_SESSION["helloweba_num"]){  
  4.    echo '1';  

后臺根據提交的驗證碼與保存在session中的驗證碼比對,完成驗證.

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 云南省| 定西市| 西贡区| 兴海县| 丹东市| 阳春市| 彭水| 潜山县| 衡水市| 肇州县| 汝阳县| 当雄县| 萨嘎县| 嵩明县| 宝应县| 海淀区| 乐至县| 忻州市| 修文县| 伊春市| 津市市| 内丘县| 沁阳市| 长顺县| 洛扎县| 五台县| 浑源县| 安陆市| 来宾市| 香格里拉县| 宿迁市| 永顺县| 甘谷县| 察隅县| 赤壁市| 武威市| 宝坻区| 株洲县| 瓦房店市| 江西省| 江西省|