php如何實現獲取驗證碼

2021-09-22 16:00:32

php實現獲取驗證碼的方法:【<?php session_start();$image = imagecreatetruecolor(100, 30);imagecolorallocate(int im, int red, int...】。

本文操作環境:windows10系統、php 7、thinkpad t480電腦。

在日常生活中我們會經常使用到驗證碼功能,那麼如果我們要自己實現一個驗證碼功能該如何去做呢?下面我們給出具體的實現程式碼,供大家參考!

如果你是一名初學者,那麼我強烈建議你跟著程式碼中的註釋一步步來,而不是直接複製程式碼。

新建一個captcha.php:

<?php
  //11>設定session,必須處於指令碼最頂部
  session_start();
  
 
  /*$image = imagecreatetruecolor(100, 30);    //1>設定驗證碼圖片大小的函數
  //5>設定驗證碼顏色 imagecolorallocate(int im, int red, int green, int blue);
  $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff
  //6>區域填充 int imagefill(int im, int x, int y, int col) (x,y) 所在的區域著色,col 表示欲塗上的顏色
  imagefill($image, 0, 0, $bgcolor);
  //10>設定變數
  $captcha_code = "";*/
  
  
    //7>生成亂數字
  for($i=0;$i<4;$i++){
    //設定字型大小
    $fontsize = 6;    
    //設定字型顏色,隨機顏色
    $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));      //0-120深顏色
    //設定數位
    $fontcontent = rand(0,9);
    //10>.=連續定義變數
    $captcha_code .= $fontcontent;  
    //設定座標
    $x = ($i*100/4)+rand(5,10);
    $y = rand(5,10);
 
    imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);
  }
  //10>存到session
  $_SESSION['authcode'] = $captcha_code;
  //8>增加干擾元素,設定雪花點
  for($i=0;$i<200;$i++){
    //設定點的顏色,50-200顏色比數位淺,不干擾閱讀
    $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));    
    //imagesetpixel — 畫一個單一畫素
    imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);
  }
  //9>增加干擾元素,設定橫線
  for($i=0;$i<4;$i++){
    //設定線的顏色
    $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));
    //設定線,兩點一線
    imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);
  }
 
  //2>設定頭部,image/png
  header('Content-Type: image/png');
  //3>imagepng() 建立png圖形函數
  imagepng($image);
  //4>imagedestroy() 結束圖形函數 銷燬$image
  imagedestroy($image);

接著就是靜態頁的程式碼了:index.html

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>無標題檔案</title>
</head>

<body>

<form method="post" action="./form.php">
  <p>驗證碼: <img id="captcha_img" border='1' src='./captcha.php?r=echo rand(); ?>' style="width:100px; height:30px" />
    <a href="javascript:void(0)" onclick="document.getElementById('captcha_img').src='./captcha.php?r='+Math.random()">換一個?</a>
  </p>
  <P>請輸入驗證碼:<input type="text" name='authcode' value=''/></p>
  <p><input type='submit' value='提交' style='padding:6px 5px;'/></p>
</form>

</body>
</html>

從index.html可以看到,提交的表單是到form.php的,所以還要有一個判斷的form.php程式碼:

<?php
  header("Content-Type:text/html;charset=utf-8");      //設定頭部資訊
  //isset()檢測變數是否設定
  if(isset($_REQUEST['authcode'])){
    session_start();
    //strtolower()小寫函數
    if(strtolower($_REQUEST['authcode'])== $_SESSION['authcode']){
      //跳轉頁面
      echo "<script language=\"javascript\">";
      echo "document.location=\"./form.php\"";
      echo "</script>";
    }else{
      //提示以及跳轉頁面
      echo "<script language=\"javascript\">";
      echo "alert('輸入錯誤!');";
      echo "document.location=\"./form.php\"";
      echo "</script>";
    }
    exit();
  }

顯示頁面如下:

a816c06f4ea219144a1747e403bfb87.png

數位加英文的驗證碼,只需更改captcha.php頁面中的 7》即可,其他兩個頁面不需要動,程式碼如下:

<?php
  //11>設定session,必須處於指令碼最頂部
  session_start();
  $image = imagecreatetruecolor(100, 30);    //1>設定驗證碼圖片大小的函數
  //5>設定驗證碼顏色 imagecolorallocate(int im, int red, int green, int blue);
  $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff
  //6>區域填充 int imagefill(int im, int x, int y, int col) (x,y) 所在的區域著色,col 表示欲塗上的顏色
  imagefill($image, 0, 0, $bgcolor);
  //10>設定變數
  $captcha_code = "";
//7>生成隨機的字母和數位
  for($i=0;$i<4;$i++){
    //設定字型大小
    $fontsize = 8;    
    //設定字型顏色,隨機顏色
    $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));      //0-120深顏色
    //設定需要隨機取的值,去掉容易出錯的值如0和o
    $data ='abcdefghigkmnpqrstuvwxy3456789';
    //取出值,字串擷取方法  strlen獲取字串長度
    $fontcontent = substr($data, rand(0,strlen($data)),1);
    //10>.=連續定義變數
    $captcha_code .= $fontcontent;    
    //設定座標
    $x = ($i*100/4)+rand(5,10);
    $y = rand(5,10);
    imagestring($image,$fontsize,$x,$y,$fontcontent,$fontcolor);
  }
  //10>存到session
  $_SESSION['authcode'] = $captcha_code;
  //8>增加干擾元素,設定雪花點
  for($i=0;$i<200;$i++){
    //設定點的顏色,50-200顏色比數位淺,不干擾閱讀
    $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));    
    //imagesetpixel — 畫一個單一畫素
    imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);
  }
  //9>增加干擾元素,設定橫線
  for($i=0;$i<4;$i++){
    //設定線的顏色
    $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));
    //設定線,兩點一線
    imageline($image,rand(1,99), rand(1,29),rand(1,99), rand(1,29),$linecolor);
  }
 
  //2>設定頭部,image/png
  header('Content-Type: image/png');
  //3>imagepng() 建立png圖形函數
  imagepng($image);
  //4>imagedestroy() 結束圖形函數 銷燬$image
  imagedestroy($image);

顯示頁面如下:

61a9496363822c9e89ff940ef3b469c.png

生成漢字類驗證碼,在執行過程中,提示亂碼錯誤,無法顯示,未能解決,程式碼如下:

php
  //11>設定session,必須處於指令碼最頂部
  session_start();
 
  //1>設定驗證碼圖片大小的函數
  $image = imagecreatetruecolor(200, 60);    
  //5>設定驗證碼顏色 imagecolorallocate(int im, int red, int green, int blue);
  $bgcolor = imagecolorallocate($image,255,255,255); //#ffffff
  //6>區域填充 int imagefill(int im, int x, int y, int col) (x,y) 所在的區域著色,col 表示欲塗上的顏色
  imagefill($image, 0, 0, $bgcolor);
  //7>設定ttf字型
  $fontface = 'FZYTK.TTF';
  //7>設定字型檔,實現簡單的數位儲備
  $str='天地不仁以萬物為芻狗聖人不仁以百姓為芻狗這句經常出現在控訴暴君暴政上地殘暴不仁把萬物都當成低賤的豬狗來看待而那些高高在上的所謂聖人們也沒兩樣還不是把我們老百姓也當成豬狗不如的東西但實在正取的解讀是地不情感用事對萬物一視同仁聖人不情感用事對百姓一視同仁執子之手與子偕老當男女主人公含情脈脈看著對方說了句執子之手與子偕老女方淚眼朦朧含羞地回一句討厭啦這樣的情節我們是不是見過很多但是我們來看看這句的原句死生契闊與子成說執子之手與子偕老於嗟闊兮不我活兮于嗟洵兮不我信兮意思是說戰士之間的約定說要一起死現在和我約定的人都走了我怎麼活啊赤裸裸的兄弟江湖戰友友誼啊形容好基友的基情比男女之間的愛情要合適很多吧';
  //str_split()切割字串為一個陣列,一箇中文在utf_8為3個字元
  $strdb = str_split($str,3);  
  //>11
  $captcha_code = '';
  //8>生成隨機的漢子
  for($i=0;$i<4;$i++){
    //設定字型顏色,隨機顏色
    $fontcolor = imagecolorallocate($image, rand(0,120),rand(0,120), rand(0,120));      //0-120深顏色
    //隨機選取中文
    $in = rand(0,count($strdb));
    $cn = $strdb[$in];
    //將中文記錄到將儲存到session的字串中
    $captcha_code .= $cn;
    /*imagettftext (resource $image ,float $size ,float $angle ,int $x ,int $y,int $color,
    string $fontfile ,string $text ) 幕布 ,尺寸,角度,座標,顏色,字型路徑,文字字串
    mt_rand()生成更好的亂數,比rand()快四倍*/
    imagettftext($image, mt_rand(20,24),mt_rand(-60,60),(40*$i+20),mt_rand(30,35),$fontcolor,$fontface,$cn);
  }
  //11>存到session
  $_SESSION['authcode'] = $captcha_code;
  //9>增加干擾元素,設定點
  for($i=0;$i<200;$i++){
    //設定點的顏色,50-200顏色比數位淺,不干擾閱讀
    $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));    
    //imagesetpixel — 畫一個單一畫素
    imagesetpixel($image, rand(1,199), rand(1,59), $pointcolor);
  }
  //10>增加干擾元素,設定線
  for($i=0;$i<4;$i++){
    //設定線的顏色
    $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));
    //設定線,兩點一線
    imageline($image,rand(1,199), rand(1,59),rand(1,199), rand(1,59),$linecolor);
  }
 
  //2>設定頭部,image/png
  header('Content-Type: image/png');
  //3>imagepng() 建立png圖形函數
  imagepng($image);
  //4>imagedestroy() 結束圖形函數 銷燬$image
  imagedestroy($image);

推薦學習:

以上就是php如何實現獲取驗證碼的詳細內容,更多請關注TW511.COM其它相關文章!