首頁 >後端開發 >php教程 >php中使用GD函式庫做驗證碼實作驗證碼功能

php中使用GD函式庫做驗證碼實作驗證碼功能

墨辰丷
墨辰丷原創
2018-06-04 10:56:371566瀏覽

本文要分享給大家的是使用php的GD函式庫來實現驗證碼功能的方法和全部程式碼,有需要的小夥伴可以參考下

<?php 
require_once &#39;string.func.php&#39;;
//通过GD库做验证码
/**
 *添加验证文字
 * @param int $type
 * @param int $length
*/
function buildRandomString($type=1,$length=4){
  $row=&#39;&#39;;
  if($type==1){
    $row=join(&#39;&#39;,range(0, 9));
  }else if($type==2){
    $row=join(&#39;&#39;, array_merge(range(&#39;a&#39;,&#39;z&#39;),range(&#39;A&#39;, &#39;Z&#39;)));
  }else if($type==3){
    $row=join(&#39;&#39;, array_merge(range(&#39;a&#39;,&#39;z&#39;),range(&#39;A&#39;, &#39;Z&#39;),range(0, 9)));
  };
  $row=str_shuffle($row);
  
  $row=substr($row,0,$length);
  return $row;
}
/**
 * 生成缩略图
 * @param int $type //包含数字或者英文
 * @param int $length 多少个字符
 * @param int $pixel 干扰小点的密度
 * @param int $dst_h 干扰线的密度
 * @param string //验证码在$_SESSION中的名字
 */

function verifyImage($type=1,$length=4,$pixel=0,$line=0,$sess_name = "verify"){
  //session_start();
  //创建画布
  $width = 100;
  $height = 40;
  $image = imagecreatetruecolor ( $width, $height );
  $white = imagecolorallocate ( $image, 255, 255, 255 );
  $black = imagecolorallocate ( $image, 0, 0, 0 );
  //用填充矩形填充画布
  imagefilledrectangle ( $image, 1, 1, $width - 2, $height - 2, $white );
  $chars = buildRandomString ( $type, $length );
  $_SESSION [$sess_name] = $chars;
  //$fontfiles = array ("MSYH.TTF", "MSYHBD.TTF", "SIMLI.TTF", "SIMSUN.TTC", "SIMYOU.TTF", "STZHONGS.TTF" );
  $fontfiles = array ("SIMKAI.TTF" );
  //由于字体文件比较大,就只保留一个字体,如果有需要的同学可以自己添加字体,字体在你的电脑中的fonts文件夹里有,直接运行输入fonts就能看到相应字体
  for($i = 0; $i < $length; $i ++) {
    $size = mt_rand ( 14, 18 );
    $angle = mt_rand ( - 15, 15 );
    $x = 5 + $i * $size;
    $y = mt_rand ( 20, 26 );
    $fontfile = "../fonts/" . $fontfiles [mt_rand ( 0, count ( $fontfiles ) - 1 )];
    $color = imagecolorallocate ( $image, mt_rand ( 50, 90 ), mt_rand ( 80, 200 ), mt_rand ( 90, 180 ) );
    $text = substr ( $chars, $i, 1 );
    imagettftext ( $image, $size, $angle, $x, $y, $color, $fontfile, $text );
  }
  if ($pixel) {
    for($i = 0; $i < 50; $i ++) {
      imagesetpixel ( $image, mt_rand ( 0, $width - 1 ), mt_rand ( 0, $height - 1 ), $black );
    }
  }
  if ($line) {
    for($i = 1; $i < $line; $i ++) {
      $color = imagecolorallocate ( $image, mt_rand ( 50, 90 ), mt_rand ( 80, 200 ), mt_rand ( 90, 180 ) );
      imageline ( $image, mt_rand ( 0, $width - 1 ), mt_rand ( 0, $height - 1 ), mt_rand ( 0, $width - 1 ), mt_rand ( 0, $height - 1 ), $color );
    }
  }
  header ( "content-type:image/gif" );
  imagegif ( $image );
  imagedestroy ( $image );
}

主要要點:

1、如果前面沒有申明session_start();則需要申明;
2、字體可以在cmf輸入fonts下載到自己定義的fonts資料夾;
3、$_SESSION [$sess_name]可以透過$_POST取得使用者輸入的驗證碼來比較。

總結:以上就是這篇文章的全部內容,希望能對大家的學習有所幫助。

相關推薦:

php時間函數的用法與實例分析

PHP引用傳回用法實例詳解

php實作取得一定範圍內取N個不重複的隨機數的方法

##

以上是php中使用GD函式庫做驗證碼實作驗證碼功能的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn