PHP生成各種常見(jiàn)驗(yàn)證碼和Ajax驗(yàn)證過(guò)程
驗(yàn)證碼在WEB應(yīng)用中非常重要,通常用來(lái)防止用戶惡意提交表單,如惡意注冊(cè)和登錄、論壇惡意灌水等。本文將通過(guò)實(shí)例講解使用PHP生成各種常見(jiàn)的驗(yàn)證碼包括數(shù)字驗(yàn)證碼、數(shù)字+字母驗(yàn)證碼、中文驗(yàn)證碼、算術(shù)驗(yàn)證碼等等以及其Ajax驗(yàn)證過(guò)程。

PHP生成驗(yàn)證碼圖片
PHP生成驗(yàn)證碼的原理:使用PHP的GD庫(kù),生成一張帶驗(yàn)證碼的圖片,并將驗(yàn)證碼保存在Session中。
PHP生成驗(yàn)證碼的大致流程有:
1.產(chǎn)生一張png的圖片;
2.為圖片設(shè)置背景色;
3.設(shè)置字體顏色和樣式;
4.產(chǎn)生4位數(shù)的隨機(jī)的驗(yàn)證碼;
5.把產(chǎn)生的每個(gè)字符調(diào)整旋轉(zhuǎn)角度和位置畫(huà)到png圖片上;
6.加入噪點(diǎn)和干擾線防止注冊(cè)機(jī)器分析原圖片來(lái)惡意破解驗(yàn)證碼;
7.輸出圖片;
8.釋放圖片所占內(nèi)存。
示例:
session_start();
getCode(4,60,20);
function getCode($num,$w,$h) {
$code = "";
for ($i = 0; $i < $num; $i++) {
$code .= rand(0, 9);
}
//4位驗(yàn)證碼也可以用rand(1000,9999)直接生成
//將生成的驗(yàn)證碼寫(xiě)入session,備驗(yàn)證時(shí)用
$_SESSION["helloweba_num"] = $code;
//創(chuàng)建圖片,定義顏色值
header("Content-type: image/PNG");
$im = imagecreate($w, $h);
$black = imagecolorallocate($im, 0, 0, 0);
$gray = imagecolorallocate($im, 200, 200, 200);
$bgcolor = imagecolorallocate($im, 255, 255, 255);
//填充背景
imagefill($im, 0, 0, $gray);
//畫(huà)邊框
imagerectangle($im, 0, 0, $w-1, $h-1, $black);
//隨機(jī)繪制兩條虛線,起干擾作用
$style = array ($black,$black,$black,$black,$black,
$gray,$gray,$gray,$gray,$gray
);
imagesetstyle($im, $style);
$y1 = rand(0, $h);
$y2 = rand(0, $h);
$y3 = rand(0, $h);
$y4 = rand(0, $h);
imageline($im, 0, $y1, $w, $y3, IMG_COLOR_STYLED);
imageline($im, 0, $y2, $w, $y4, IMG_COLOR_STYLED);
//在畫(huà)布上隨機(jī)生成大量黑點(diǎn),起干擾作用;
for ($i = 0; $i < 80; $i++) {
imagesetpixel($im, rand(0, $w), rand(0, $h), $black);
}
//將數(shù)字隨機(jī)顯示在畫(huà)布上,字符的水平間距和位置都按一定波動(dòng)范圍隨機(jī)生成
$strx = rand(3, 8);
for ($i = 0; $i < $num; $i++) {
$strpos = rand(1, 6);
imagestring($im, 5, $strx, $strpos, substr($code, $i, 1), $black);
$strx += rand(8, 12);
}
imagepng($im);//輸出圖片
imagedestroy($im);//釋放圖片所占內(nèi)存
}
代碼中,自定義函數(shù)getCode()詮釋了驗(yàn)證碼的生成過(guò)程。運(yùn)用PHP GD庫(kù)自帶的圖像處理函數(shù),能輕松生成各種想要的圖片效果。
imagecreate() :創(chuàng)建一個(gè)新圖像
imagecolorallocate() :為圖像分配顏色
imagefill() :填充圖像
imagerectangle() :畫(huà)一個(gè)矩形(邊框)
imagesetstyle() :設(shè)置畫(huà)線風(fēng)格
imageline() :畫(huà)一條線段
imagesetpixel() :畫(huà)點(diǎn)像素
imagepng() :以PNG格式將圖像輸出到瀏覽器或文件
imagedestroy() :釋放圖片所占內(nèi)存
將上述代碼保存為code_num.php,以便調(diào)用。
Ajax刷新和驗(yàn)證
驗(yàn)證碼生成后,我們要在實(shí)際的項(xiàng)目中應(yīng)用,通常我們使用ajax可以實(shí)現(xiàn)點(diǎn)擊驗(yàn)證碼時(shí)刷新生成新的驗(yàn)證碼(有時(shí)生成的驗(yàn)證碼肉眼很難識(shí)別),即“看 不清換一張”。填寫(xiě)驗(yàn)證碼后,還需要驗(yàn)證所填驗(yàn)證碼是否正確,驗(yàn)證的過(guò)程是要后臺(tái)程序來(lái)完成,但是我們也可以通過(guò)ajax來(lái)實(shí)現(xiàn)無(wú)刷新驗(yàn)證。
我們建立一個(gè)前端頁(yè)面index.html,載入jquery,同時(shí)在body中加入驗(yàn)證碼表單元素:
<p>驗(yàn)證碼:<input type="text" class="input" id="code_num" name="code_num" maxlength="4" /> <img src="code_num.php" id="getcode_num" title="看不清,點(diǎn)擊換一張" align="absmiddle"></p> <p><input type="button" class="btn" id="chk_num" value="提交" /></p>
html代碼中,<img src="code_num.php"即調(diào)用了生成的驗(yàn)證碼,當(dāng)點(diǎn)擊驗(yàn)證碼時(shí),刷新生成新的驗(yàn)證碼:
$(function(){
//數(shù)字驗(yàn)證
$("#getcode_num").click(function(){
$(this).attr("src",'code_num.php?' + Math.random());
});
...
});
刷新驗(yàn)證碼,其實(shí)就是重新請(qǐng)求了驗(yàn)證碼生成程序,這里要注意的是調(diào)用code_num.php時(shí)要帶上隨機(jī)參數(shù)防止緩存。接下來(lái)填寫(xiě)好驗(yàn)證碼之后,點(diǎn)“提交”按鈕,通過(guò)$.post(),前端向后臺(tái)chk_code.php發(fā)送ajax請(qǐng)求。
$(function(){
...
$("#chk_num").click(function(){
var code_num = $("#code_num").val();
$.post("chk_code.php?act=num",{code:code_num},function(msg){
if(msg==1){
alert("驗(yàn)證碼正確!");
}else{
alert("驗(yàn)證碼錯(cuò)誤!");
}
});
});
});
后臺(tái)chk_code.php驗(yàn)證:
session_start();
$code = trim($_POST['code']);
if($code==$_SESSION["helloweba_num"]){
echo '1';
}
后臺(tái)根據(jù)提交的驗(yàn)證碼與保存在session中的驗(yàn)證碼比對(duì),完成驗(yàn)證。
對(duì)于其他幾種驗(yàn)證的生成和使用,其原理一樣,開(kāi)發(fā)者可以根據(jù)需要,產(chǎn)生多種樣式的隨機(jī)驗(yàn)證碼,本文演示demo中提供了數(shù)字驗(yàn)證碼、數(shù)字+字母驗(yàn)證碼、中文驗(yàn)證碼、仿google驗(yàn)證碼,算術(shù)驗(yàn)證碼等。限于篇幅,其他幾種驗(yàn)證碼的生成代碼略過(guò),敬請(qǐng)諒解。
- asp.net ajax實(shí)現(xiàn)無(wú)刷新驗(yàn)證碼
- 基于Ajax用戶名驗(yàn)證、服務(wù)條款加載、驗(yàn)證碼生成的實(shí)現(xiàn)方法
- Ajax實(shí)現(xiàn)帶有驗(yàn)證碼的局部刷新登錄界面
- Ajax和PHP正則表達(dá)式驗(yàn)證表單及驗(yàn)證碼
- PHP+Ajax驗(yàn)證碼驗(yàn)證用戶登錄
- thinkphp驗(yàn)證碼的實(shí)現(xiàn)(form、ajax實(shí)現(xiàn)驗(yàn)證)
- jsp+ajax實(shí)現(xiàn)的局部刷新較驗(yàn)驗(yàn)證碼(onblur事件觸發(fā)較驗(yàn))
- Ajax提交表單時(shí)驗(yàn)證碼自動(dòng)驗(yàn)證 php后端驗(yàn)證碼檢測(cè)
- PHP+Ajax實(shí)現(xiàn)驗(yàn)證碼的實(shí)時(shí)驗(yàn)證
- 基于ajax實(shí)現(xiàn)驗(yàn)證碼功能
相關(guān)文章
Symfony2框架創(chuàng)建項(xiàng)目與模板設(shè)置實(shí)例詳解
這篇文章主要介紹了Symfony2框架創(chuàng)建項(xiàng)目與模板設(shè)置的方法,結(jié)合實(shí)例形式詳細(xì)分析了Symfony2框架的具體步驟與詳細(xì)實(shí)現(xiàn)代碼,需要的朋友可以參考下2016-03-03
Laravel5.5新特性之友好報(bào)錯(cuò)以及展示詳解
這篇文章主要給大家介紹了關(guān)于Laravel5.5新特性之友好報(bào)錯(cuò)以及展示的相關(guān)資料,文中通過(guò)圖文介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08
PHP實(shí)現(xiàn)WebSocket實(shí)例詳解
這篇文章主要介紹了PHP實(shí)現(xiàn)WebSocket實(shí)例詳解,本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
THINKPHP截取中文字符串函數(shù)實(shí)例代碼
在項(xiàng)目開(kāi)發(fā)中,我們常常會(huì)遇到英文、中文等字符串截取問(wèn)題,比如說(shuō)新聞列表頁(yè)面需要新聞內(nèi)容簡(jiǎn)介,這就要用到字符串截取了。2017-03-03
PHP上傳目錄禁止執(zhí)行php文件實(shí)例講解
這篇文章主要介紹了PHP上傳目錄禁止執(zhí)行php文件實(shí)例講解,這個(gè)是比較實(shí)用的防止惡意攻擊的方法,有需要的同學(xué)可以學(xué)習(xí)下2021-03-03
php實(shí)現(xiàn)httpclient類(lèi)示例
這篇文章主要介紹了php實(shí)現(xiàn)httpclient類(lèi)示例,需要的朋友可以參考下2014-04-04
解決Laravel 不能創(chuàng)建 migration 的問(wèn)題
今天小編就為大家分享一篇解決Laravel 不能創(chuàng)建 migration 的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10

