php校驗isbn碼的函數代碼的簡單介紹

本文目錄一覽:

php如何實現驗證碼?許昌鯉魚IT計算機電腦軟體編程培訓中心

驗證碼在表單實現越來越多了,但是用js的寫的驗證碼,總覺得不方便,所以學習了下php實現的驗證碼。好吧,其實是沒有事情干,但是又不想浪費時間,所以學習了下php實現驗證碼。正所謂,技多不壓身。而且,也可以封裝成一個函數,以後使用的時候也是很方便的,當然現在未封裝。

現在來說說簡單的純數字驗證碼吧。

如果是初學者,建議按照我代碼的注釋 //數字 一步步來。最簡單的方法,還是把整個代碼複製走了。

新建一個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) 所在的區域著色,col 表示欲塗上的顏色

imagefill($image, 0, 0, $bgcolor); //10設置變數

$captcha_code = “”; //7生成隨機數字

for($i=0;$i4;$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;$i200;$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;$i4;$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’); //3imagepng() 建立png圖形函數

imagepng($image); //4imagedestroy() 結束圖形函數 銷毀$image

imagedestroy($image);

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

doctype htmlhtml

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

pinput type=’submit’ value=’提交’ style=’padding:6px 5px;’/p

bodyhtml

從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();

}

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

廢話不多說了,拉代碼吧。

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

imagefill($image, 0, 0, $bgcolor); //10設置變數

$captcha_code = “”; //7生成隨機的字母和數字

for($i=0;$i4;$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;$i200;$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;$i4;$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’); //3imagepng() 建立png圖形函數

imagepng($image); //4imagedestroy() 結束圖形函數 銷毀$image

imagedestroy($image);

其他的兩個頁面,不許要修改。

一般而言,現在就已經夠用了。但是就像動漫一樣,總會有番外。

那麼,我們來個漢字的番外吧。其實我也準備將漢字的驗證碼放到我的畢業設計裡面,雖然現在很流行滑動驗證碼,但是本人畢竟不是專門學習js的。

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

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;$i4;$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;$i200;$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;$i4;$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’); //3imagepng() 建立png圖形函數

imagepng($image); //4imagedestroy() 結束圖形函數 銷毀$image

imagedestroy($image);

其他的頁面也是不需要修改的。

效果圖如下:

php的驗證碼提示怎樣製作

一般製作驗證碼會按照下面的幾步走:

一:創建出來一個圖片,通常我們成為源,可以用imagecreatetruecolor()這個函數搞定

二:給這個源 添加背景色,同時設置文本顯示的顏色,GD庫函數為我們提供了imagecolorallocate()函數

三:材料弄好了,我們要給它添點內容了,就是我們隨機生成的數字或者字母,甚至可以是它們的組合,這裡我們可以選擇兩個函數 imagettftext()、imagesrting(),這兩個函數的不同,我們會在後面講解。

例:

?php

session_start();//開啟session,用來記錄獲得的驗證碼,這個函數要寫在程序的開頭,不然會出現錯誤

header(「Content-type :image/gif」);//把文件的返回類型設為image/gif格式,這個格式可以輸出圖片

$codelen=4;//設置你要讓用戶輸入字元的個數,一般為4,過長用戶體驗不好。

$charset =」ABCDEFGHKLMNPRSTUVWYZ23456789″;//我們可以盡量把一些難以辨認的字元去掉,比如阿拉伯數字0和字母o,這也是提高用戶體驗的一種方法。

$code =」;

for($i=0;$i$codelen;$i++){//用for循環得到4個隨機的字元,在這裡用到了mt_rand,這個函數比rand的效率要高的多,建議大家用這個

$code .=$charset{mt_rand(0,strlen($charset)-1)};

}

$_SESSION[‘code’]=$code;//下篇關於session驗證的文章將會用到

$width = 80;

$height = 40;

$im = imagecreatetruecolor($width,$height);//用imagecreatetruecolor()函數來建立一個新的圖片,裡面的兩個數值分別是寬度和高度,這是製作驗證碼的第一步

$bg = imagecolorallocate($im,255,255,0); //圖片背景的顏色,這裡是第二步

$textcolor = imagecolorallocate($im,255,0,0);//文字的顏色

imagefill($im,0,0,$bg);//給圖片填充背景色

//好了上面的鋪墊任務做的差不多了,現在關鍵就是讓字元顯示在圖片上,這裡有兩種方法我們一一介紹。

$font =」ggbi.ttf」;//如果你有字體的話 就填上字體的相對路徑,如果沒有就留空。下面的兩個用法我會一一講解。

if($font!==」”){

for($num=0;$num4;$num++){

imagettftext($im,mt_rand(12,16),(mt_rand(0,75)+330)%360,5+15*$num,20+mt_rand(2,5),$textcolor,$font,$code[$num]);//這裡是第三步

}

}

else{

for($num=0;$num4;$num++){

imagestring($im,5,10+15*$num,10+mt_rand(0,5),$code[$num],$textcolor);

}

}

header(「Content-type: image/jpeg」);

imagejpeg($im);

?

php的圖片驗證碼代碼

這個是phpcms的驗證碼,經過十幾萬個網站經驗的,非常好用

?php

session_start();

$enablegd = 1;

//判斷圖像處理函數是否存在

$funcs = array(‘imagecreatetruecolor’,’imagecolorallocate’,’imagefill’,’imagestring’,’imageline’,’imagerotate’,’imagedestroy’,’imagecolorallocatealpha’,’imageellipse’,’imagepng’);

foreach($funcs as $func)

{

if(!function_exists($func))

{

$enablegd = 0;

break;

}

}

ob_clean(); //清理緩衝

if($enablegd)

{

//create captcha

$consts = ‘cdfgkmnpqrstwxyz23456’;

$vowels = ‘aek23456789’;

for ($x = 0; $x 6; $x++)

{

$const[$x] = substr($consts, mt_rand(0,strlen($consts)-1),1); //獲取$consts中的一個隨機數

$vow[$x] = substr($vowels, mt_rand(0,strlen($vowels)-1),1); //獲取$vowels中的一個隨機數

}

$radomstring = $const[0] . $vow[0] .$const[2] . $const[1] . $vow[1] . $const[3] . $vow[3] . $const[4];

$_SESSION[‘checkcode’] = $string = substr($radomstring,0,4); //顯示4個字元

$imageX = strlen($radomstring)*8; //圖像的寬

$imageY = 20; //圖像的高

$im = imagecreatetruecolor($imageX,$imageY); //新建一個真彩色圖像

//creates two variables to store color

$background = imagecolorallocate($im, rand(180, 250), rand(180, 250), rand(180, 250)); //背景色

$foregroundArr = array(imagecolorallocate($im, rand(0, 20), rand(0, 20), rand(0, 20)),

imagecolorallocate($im, rand(0, 20), rand(0, 10), rand(245, 255)),

imagecolorallocate($im, rand(245, 255), rand(0, 20), rand(0, 10)),

imagecolorallocate($im, rand(245, 255), rand(0, 20), rand(245, 255))

);

$foreground2 = imagecolorallocatealpha($im, rand(20, 100), rand(20, 100), rand(20, 100),80); //分配顏色並說明透明度

$middleground = imagecolorallocate($im, rand(200, 160), rand(200, 160), rand(200, 160)); //中間背景

$middleground2 = imagecolorallocatealpha($im, rand(180, 140), rand(180, 140), rand(180, 140),80); //中間背景2

//與左上角的顏色相同的都會被填充

imagefill($im, 0, 0, imagecolorallocate($im, 250, 253, 254));

//往圖像上寫入文字

imagettftext($im, 12, rand(30, -30), 5, rand(14, 16), $foregroundArr[rand(0,3)], XINCHENG_ROOT.’include/fonts/ALGER.TTF’, $string[0]);

imagettftext($im, 12, rand(50, -50), 20, rand(14, 16), $foregroundArr[rand(0,3)], XINCHENG_ROOT.’include/fonts/ARIALNI.TTF’, $string[1]);

imagettftext($im, 12, rand(50, -50), 35, rand(14, 16), $foregroundArr[rand(0,3)], XINCHENG_ROOT.’include/fonts/ALGER.TTF’, $string[2]);

imagettftext($im, 12, rand(30, -30), 50, rand(14, 16), $foregroundArr[rand(0,3)], XINCHENG_ROOT.’include/fonts/arial.ttf’, $string[3]);

//畫邊框

$border = imagecolorallocate($im, 133, 153, 193);

imagerectangle($im, 0, 0, $imageX – 1, $imageY – 1, $border);

//畫一些隨機出現的點

$pointcol = imagecolorallocate($im, rand(0,255), rand(0,255), rand(0,255));

for ($i=0;$i80;$i++)

{

imagesetpixel($im,rand(2,$imageX-2),rand(2,$imageX-2),$pointcol);

}

//畫隨機出現的線

for ($x=0; $x9;$x++)

{

if(mt_rand(0,$x)%2==0)

{

imageline($im, rand(0, 120), rand(0, 120), rand(0, 120), rand(0, 120), rand(0, 999999)); //畫線

imageellipse($im, rand(0, 120), rand(0, 120), rand(0, 120), rand(0, 120), $middleground2); //畫橢圓

}

else

{

imageline($im, rand(0, 120), rand(0, 120), rand(0, 120), rand(0, 120), rand(0, 999999));

imageellipse($im, rand(0, 120), rand(0, 120), rand(0, 120), rand(0, 120), $middleground);

}

}

//output to browser

header(“content-type:image/png\r\n”);

imagepng($im);

imagedestroy($im);

}

else

{

$files = glob(XINCHENG_ROOT.’images/checkcode/*.jpg’);

if(!is_array($files)) die(‘請檢查文件目錄完整性:/images/checkcode/’);

$checkcodefile = $files[rand(0, count($files)-1)]; //隨機其中一個文件

$_SESSION[‘checkcode’] = substr(basename($checkcodefile), 0, 4); //獲得文件名

header(“content-type:image/jpeg\r\n”);

include $checkcodefile;

}

?

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/293252.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-26 13:13
下一篇 2024-12-26 13:13

相關推薦

  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python字元串寬度不限制怎麼打代碼

    本文將為大家詳細介紹Python字元串寬度不限制時如何打代碼的幾個方面。 一、保持代碼風格的統一 在Python字元串寬度不限制的情況下,我們可以寫出很長很長的一行代碼。但是,為了…

    編程 2025-04-29
  • PHP和Python哪個好找工作?

    PHP和Python都是非常流行的編程語言,它們被廣泛應用於不同領域的開發中。但是,在考慮擇業方向的時候,很多人都會有一個問題:PHP和Python哪個好找工作?這篇文章將從多個方…

    編程 2025-04-29
  • Python中capitalize函數的使用

    在Python的字元串操作中,capitalize函數常常被用到,這個函數可以使字元串中的第一個單詞首字母大寫,其餘字母小寫。在本文中,我們將從以下幾個方面對capitalize函…

    編程 2025-04-29
  • Python基礎代碼用法介紹

    本文將從多個方面對Python基礎代碼進行解析和詳細闡述,力求讓讀者深刻理解Python基礎代碼。通過本文的學習,相信大家對Python的學習和應用會更加輕鬆和高效。 一、變數和數…

    編程 2025-04-29
  • Python中set函數的作用

    Python中set函數是一個有用的數據類型,可以被用於許多編程場景中。在這篇文章中,我們將學習Python中set函數的多個方面,從而深入了解這個函數在Python中的用途。 一…

    編程 2025-04-29
  • 三角函數用英語怎麼說

    三角函數,即三角比函數,是指在一個銳角三角形中某一角的對邊、鄰邊之比。在數學中,三角函數包括正弦、餘弦、正切等,它們在數學、物理、工程和計算機等領域都得到了廣泛的應用。 一、正弦函…

    編程 2025-04-29
  • 單片機列印函數

    單片機列印是指通過串口或並口將一些數據列印到終端設備上。在單片機應用中,列印非常重要。正確的列印數據可以讓我們知道單片機運行的狀態,方便我們進行調試;錯誤的列印數據可以幫助我們快速…

    編程 2025-04-29
  • Python簡單數學計算

    本文將從多個方面介紹Python的簡單數學計算,包括基礎運算符、函數、庫以及實際應用場景。 一、基礎運算符 Python提供了基礎的算術運算符,包括加(+)、減(-)、乘(*)、除…

    編程 2025-04-29

發表回復

登錄後才能評論