一级日韩免费大片,亚洲一区二区三区高清,性欧美乱妇高清come,久久婷婷国产麻豆91天堂,亚洲av无码a片在线观看

php語(yǔ)言

php如何實(shí)現驗證碼

時(shí)間:2025-03-15 18:58:43 php語(yǔ)言 我要投稿

php如何實(shí)現驗證碼

  驗證碼在表單實(shí)現越來(lái)越多了,但是用js的寫(xiě)的驗證碼,總覺(jué)得不方便,所以學(xué)習了下php實(shí)現的驗證碼。好吧,其實(shí)是沒(méi)有事情干,但是又不想浪費時(shí)間,所以學(xué)習了下php實(shí)現驗證碼。正所謂,技多不壓身。而且,也可以封裝成一個(gè)函數,以后使用的時(shí)候也是很方便的,當然現在未封裝。下面是小編為大家帶來(lái)的關(guān)于php如何實(shí)現驗證碼的知識,歡迎閱讀。

  簡(jiǎn)單的純數字驗證碼

  如果是初學(xué)者,建議按照我代碼的注釋 //數字 一步步來(lái)。最簡(jiǎn)單的方法,還是把整個(gè)代碼復制走了。

  新建一個(gè)captcha.php:

  php

  //10>設置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) 所在的區域著(zhù)色,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>增加干擾元素,設置雪花點(diǎn)

  for($i=0;$i<200;$i++){

  //設置點(diǎn)的顏色,50-200顏色比數字淺,不干擾閱讀

  $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));

  //imagesetpixel — 畫(huà)一個(gè)單一像素

  imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);

  }

  //9>增加干擾元素,設置橫線(xiàn)

  for($i=0;$i<4;$i++){

  //設置線(xiàn)的顏色

  $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));

  //設置線(xiàn),兩點(diǎn)一線(xiàn)

  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() 結束圖形函數 銷(xiāo)毀$image

  imagedestroy($image);

  接著(zhù)就是靜態(tài)頁(yè)的代碼了:index.html

  doctype html>

  <html>

  <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()">換一個(gè)?a>

  p>

  <P>請輸入驗證碼:<input type="text" name='authcode' value=''/>p>

  <p><input type='submit' value='提交' style='padding:6px 5px;'/>p>

  body>

  html>

  從index.html可以看到,提交的表單是到form.php的,所以還要有一個(gè)判斷的form.php代碼:

  php

  header("Content-Type:text/html;charset=utf-8"); //設置頭部信息

  //isset()檢測變量是否設置

  if(isset($_REQUEST['authcode'])){

  session_start();

  //strtolower()小寫(xiě)函數

  if(strtolower($_REQUEST['authcode'])== $_SESSION['authcode']){

  //跳轉頁(yè)面

  echo "<script language="javascript">";

  echo "document.location="./form.php"";

  echo "</script>";

  }else{

  //提示以及跳轉頁(yè)面

  echo "<script language="javascript">";

  echo "alert('輸入錯誤!');";

  echo "document.location="./form.php"";

  echo "</script>";

  }

  exit();

  }

  顯示頁(yè)面如下:

  那么,純數字的實(shí)現了,數字加英文的也應該不難了。要修改的代碼 只是在 captcha.php 將 //7>生成隨機數字 修改成 //7>生成隨機的字母和數字,如果你真的很可愛(ài)的就修改這幾個(gè)字就認為可以實(shí)現的話(huà),那么祝賀你,你永遠保持快樂(lè )。腦殘兒童歡樂(lè )多。

  廢話(huà)不多說(shuō)了,拉代碼吧。

  php

  //10>設置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) 所在的區域著(zhù)色,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獲取字符串長(cháng)度

  $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>增加干擾元素,設置雪花點(diǎn)

  for($i=0;$i<200;$i++){

  //設置點(diǎn)的顏色,50-200顏色比數字淺,不干擾閱讀

  $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));

  //imagesetpixel — 畫(huà)一個(gè)單一像素

  imagesetpixel($image, rand(1,99), rand(1,29), $pointcolor);

  }

  //9>增加干擾元素,設置橫線(xiàn)

  for($i=0;$i<4;$i++){

  //設置線(xiàn)的顏色

  $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));

  //設置線(xiàn),兩點(diǎn)一線(xiàn)

  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() 結束圖形函數 銷(xiāo)毀$image

  imagedestroy($image);

  其他的兩個(gè)頁(yè)面,不許要修改。

  一般而言,現在就已經(jīng)夠用了。但是就像動(dòng)漫一樣,總會(huì )有番外。

  那么,我們來(lái)個(gè)漢字的番外吧。其實(shí)我也準備將漢字的驗證碼放到我的畢業(yè)設計里面,雖然現在很流行滑動(dòng)驗證碼,但是本人畢竟不是專(zhuān)門(mén)學(xué)習js的。

  而且,還可以和答辯的老師說(shuō),我們驗證碼不需要素材,連圖片也是生成的,用自己的知識裝13,也沒(méi)有設么的。

  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) 所在的區域著(zhù)色,col 表示欲涂上的顏色

  imagefill($image, 0, 0, $bgcolor);

  //7>設置ttf字體

  $fontface = 'FZYTK.TTF';

  //7>設置字庫,實(shí)現簡(jiǎn)單的數字儲備

  $str='天地不仁以萬(wàn)物為芻狗圣人不仁以百姓為芻狗這句經(jīng)常出現在控訴暴君暴政上地殘暴不仁把萬(wàn)物都當成低賤的豬狗來(lái)看待而那些高高在上的所謂圣人們也沒(méi)兩樣還不是把我們老百姓也當成豬狗不如的東西但實(shí)在正取的解讀是地不情感用事對萬(wàn)物一視同仁圣人不情感用事對百姓一視同仁執子之手與子偕老當男女主人公含情脈脈看著(zhù)對方說(shuō)了句執子之手與子偕老女方淚眼朦朧含羞地回一句討厭啦這樣的情節我們是不是見(jiàn)過(guò)很多但是我們來(lái)看看這句的原句死生契闊與子成說(shuō)執子之手與子偕老于嗟闊兮不我活兮于嗟洵兮不我信兮意思是說(shuō)戰士之間的約定說(shuō)要一起死現在和我約定的人都走了我怎么活啊裸的兄弟江湖戰友友誼啊形容好基友的基情比男女之間的愛(ài)情要合適很多吧';

  //str_split()切割字符串為一個(gè)數組,一個(gè)中文在utf_8為3個(gè)字符

  $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>增加干擾元素,設置點(diǎn)

  for($i=0;$i<200;$i++){

  //設置點(diǎn)的顏色,50-200顏色比數字淺,不干擾閱讀

  $pointcolor = imagecolorallocate($image,rand(50,200), rand(50,200), rand(50,200));

  //imagesetpixel — 畫(huà)一個(gè)單一像素

  imagesetpixel($image, rand(1,199), rand(1,59), $pointcolor);

  }

  //10>增加干擾元素,設置線(xiàn)

  for($i=0;$i<4;$i++){

  //設置線(xiàn)的顏色

  $linecolor = imagecolorallocate($image,rand(80,220), rand(80,220),rand(80,220));

  //設置線(xiàn),兩點(diǎn)一線(xiàn)

  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() 結束圖形函數 銷(xiāo)毀$image

  imagedestroy($image);


【php如何實(shí)現驗證碼】相關(guān)文章:

php實(shí)現驗證碼制作08-12

如何實(shí)現php登陸表單提交CSRF及驗證碼05-20

PHP中多態(tài)如何實(shí)現05-06

php如何實(shí)現快速排序04-03

PHP如何遞歸實(shí)現json類(lèi)06-27

如何實(shí)現PHP圖片裁剪與縮放07-13

如何用PHP實(shí)現找回密碼02-03

PHP弱類(lèi)型變量是如何實(shí)現的05-31

PHP中如何實(shí)現crontab代碼05-30

一级日韩免费大片,亚洲一区二区三区高清,性欧美乱妇高清come,久久婷婷国产麻豆91天堂,亚洲av无码a片在线观看