成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

PHP驗證碼在驗證頁面中的應用分析

開發 后端
對于PHP語言的初學者來說,對于PHP驗證碼的編寫也許還是比較生疏的。我們希望本文所描述的內容可以幫助新手們熟悉PHP驗證碼的具體應用。

對于一個網站來說,肯定會需要一個提供驗證功能的頁面。那么我們現在就需要考慮驗證頁面中的驗證碼的應用了。我們接下來將要為大家具體講解有關PHP驗證碼的相關應用方法。

#t#一、準備一個展示并提交PHP驗證碼的頁面

  1. <?php    
  2.     
  3.     @header("content-type:text/html; charset=UTF-8");     
  4.     
  5.     //打開session     
  6.     
  7.     session_start();     
  8.     
  9. ?>    
  10.     
  11. <html>    
  12.     
  13.     <head>    
  14.     
  15.        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />    
  16.     
  17.        <title>PHP驗證碼示例</title>    
  18.     
  19.     </head>    
  20.     
  21.     <body>    
  22.     
  23.        驗證碼:<br/>    
  24.     
  25.        <iframe id="iimg" height="100" width=300 src="img.php" frameborder="0" ></iframe>    
  26.     
  27.        <br/>    
  28.     
  29.        <input type=button value="看不清,換一張" onclick="iimg.location.reload();">    
  30.     
  31.        <br>    
  32.     
  33.        <form action="validate.php" method="post">    
  34.     
  35.            輸入驗證碼:<input name="imgId" style="width:60">    
  36.     
  37.            <input type="submit" value="確定">    
  38.     
  39.        </form>    
  40.     
  41.     </body>    
  42.     
  43. </html>   

二、以下是PHP驗證碼生成頁面,該頁面在***頁面中被<img>調用

  1. <?php    
  2.     
  3. Header("Content-type: image/gif");     
  4.     
  5. session_start();     
  6.     
  7. //驗證碼為隨機字符,以下是算法     
  8.     
  9. $randval;     
  10.     
  11. for($i=0;$i<7;$i++){     
  12.     
  13.     $randstr = mt_rand(ord('A'),ord('Z'));     
  14.     
  15.     srand((double)microtime()*1000000);     
  16.     
  17.     $randv = mt_rand(0,10);     
  18.     
  19.     if($randv%2==0){     
  20.     
  21.        $randval.=mt_rand(0,10);     
  22.     
  23.     }else{     
  24.     
  25.        $randval.=chr($randstr);     
  26.     
  27.     }     
  28.     
  29. }     
  30.     
  31. //注冊PHP驗證碼到session     
  32.     
  33. session_register($randval);     
  34.     
  35. //以下是繪制驗證碼圖     
  36.     
  37. $height = 50;//圖高     
  38.     
  39. $width = 100;//圖寬     
  40.     
  41. $im = ImageCreateTrueColor($width, $height);     
  42.     
  43. $white = ImageColorAllocate($im, 255, 255, 255);     
  44.     
  45. $blue = ImageColorAllocate($im, 0, 0, 64);     
  46.     
  47. ImageFill($im, 0, 0, $white);     
  48.     
  49. srand((double)microtime()*1000000000);     
  50.     
  51. ImageLine($im, mt_rand(0,$width/3), mt_rand(0,$height/3), mt_rand($width/3,$width), mt_rand($height/3,$height), $blue);     
  52.     
  53. srand((double)microtime()*1000000);     
  54.     
  55. ImageLine($im, mt_rand($width/3,$width), mt_rand(0,$height/3), mt_rand(0,$width/3), mt_rand(0,$height/3), $blue);     
  56.     
  57. srand((double)microtime()*1000000);     
  58.     
  59. ImageString($im,16 , mt_rand(0,$width - strlen($randval) * 10), mt_rand(0,$height-12), $randval, $blue);     
  60.     
  61. ImageGIF($im);     
  62.     
  63. ImageDestroy($im);     
  64.     
  65. /*     
  66.     
  67. 需要注意的是:為了支持以上繪圖函數,我們必須在PHP載入GD2圖形處理庫,可修改 php.ini 文件中的     
  68.     
  69. ;extension=php_gd2.dll     
  70.     
  71. 為     
  72.     
  73. extension=php_gd2.dll     
  74.     
  75. 即開啟GD2庫     
  76.     
  77. */     
  78.     
  79. ?>    

三、這是驗證頁面,提示PHP驗證碼是否通過驗證

  1. <?php @header("content-type:text/html; charset=UTF-8");     
  2.     
  3.     //開啟session     
  4.     
  5.     session_start();     
  6.     
  7.     //得到用戶輸入的驗證碼,并轉換成大寫     
  8.     
  9.     $imgId_req = $_REQUEST['imgId'];     
  10.     
  11.     $imgId_req = strtoupper($imgId_req);     
  12.     
  13.     //驗證該字符串是否注冊了session變量     
  14.     
  15.     if (session_is_registered($imgId_req)) {     
  16.     
  17.        echo "<font color=blue >通過驗證!</font>";     
  18.     
  19.     } else {     
  20.     
  21.        echo "<font color=red >驗證錯誤!</font>";     
  22.     
  23.     }     
  24.     
  25.     //關閉session,以清除所有注冊過的變量     
  26.     
  27.     session_destroy();     
  28.     
  29. ?>    
責任編輯:曹凱 來源: 百度博客
相關推薦

2015-09-21 15:31:05

php實現驗證碼

2013-06-19 10:19:59

2009-11-23 16:59:23

PHP圖形驗證碼

2009-12-11 15:17:52

PHP驗證碼調用

2022-02-11 07:10:15

驗證碼

2021-01-19 10:29:34

短信驗證碼密碼

2009-11-23 16:34:22

PHP GD庫

2012-05-24 15:41:38

PHP

2020-11-16 07:28:53

驗證碼

2011-11-02 12:43:33

2011-11-02 16:46:41

2019-06-18 07:12:25

驗證碼漏洞加密

2009-02-09 14:17:36

2009-08-11 14:05:28

JSP驗證碼

2015-03-23 17:58:04

驗證碼倒計時并行

2017-12-21 07:38:19

2016-11-08 19:19:06

2016-11-03 13:33:31

點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 武道仙尊动漫在线观看 | 视频在线一区二区 | 国产精品美女久久久久aⅴ国产馆 | 天天看天天爽 | 亚洲视频区 | 亚洲欧美日韩一区 | 91久久精| 黄色片在线 | 久久狠狠| 精品一区在线免费观看 | 亚洲欧美日本国产 | 人人天天操 | 久久精品av | 九色网址| 精品国产久| 中国一级大毛片 | 久综合| 亚洲成av人片在线观看 | 一区二区三区小视频 | 中文字幕av一区 | 少妇一级淫片免费播放 | www.日韩 | 天天躁人人躁人人躁狂躁 | 奇米av | 最新日韩精品 | 一区二区三区成人 | 久久鲁视频 | 欧美另类视频 | 天天爱天天操 | a级大毛片| a国产视频 | 国产精品嫩草影院精东 | 亚洲乱码国产乱码精品精98午夜 | av资源中文在线 | 91免费看片| 国产精品片aa在线观看 | 国产一区二区三区高清 | 国产精品久久久久久久久久久新郎 | 秋霞在线一区二区 | 一区二区三区国产精品 | 国产有码 |