本文實例講述了PHP 圖像處理與SESSION制作超簡單驗證碼的方法。分享給大家供大家參考,具體如下:
驗證碼的實現(xiàn)
首先我們要清楚,無論是做什么東西,在做之前一定要有思路,譬如這個驗證碼里他有些什么,為了實現(xiàn)它我們該做些什么,怎么樣去做。
這里我例舉出幾個點。
1.驗證碼肯定要有內(nèi)容。
2.驗證碼里肯定要有干擾信息,就譬如,線條干擾和點點干擾。
那么為了實現(xiàn)他們我們該如何做呢?
第一步,創(chuàng)建一個名為captcha.php的文件
在里面輸入
?php
session_start();//開啟會話
header("Content-type:image/png");//定義為圖片
$im = imagecreatetruecolor(100,30);//創(chuàng)建一個畫布的大小
$color = imagecolorallocate($im, 255, 255, 255);//填充背景顏色
imagefill($im,0,0,$color);//填充$color顏色于$im畫板區(qū)域從左上角0,0開始
$content = "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890";//驗證碼內(nèi)容
$fontsize = "6";//字體大小
$ragcha = "";//聲明一個空變量,接受驗證碼內(nèi)容并保存
這個時候,驗證碼的一些基本東西我們都完成了,定義了驗證碼的寬高,背景色驗證碼內(nèi)容,驗證碼字體大小,和一個接受驗證碼的變量,就該做第二步了。
第二步,獲取驗證碼內(nèi)容
for ($i=0; $i 4; $i++) {
//截取字符串
$char = substr($content,rand(0,strlen($content)-1),1);
//把得到的內(nèi)容輸入到ragcha里
$ragcha = $ragcha.$char;
//設置x軸與y軸的坐標
$x = $i*(100/4) + rand(5,15);
$y = rand(5,10);
//設置驗證碼內(nèi)容顏色
$fontcolor = imagecolorallocate($im,rand(0,120),rand(0,120),rand(0,120));
//輸出
imagestring($im, $fontsize, $x, $y, $char, $fontcolor);
}
//保證驗證碼內(nèi)容不丟失
$_SESSION["ragcha"] = $ragcha;
在這里我們設置了$i的變量不能大于四,然后用他乘以(100/4),保證他的的值不會大過100,再加上rand函數(shù)里隨機抽取5-15里的數(shù)值,使其的x軸坐標范圍保證在(5-90)之間,y軸的坐標保證在(5-10)之間,使其大概率的保證了內(nèi)容顯示的范圍居中
第三步,設置干擾因素
我們要明白,在驗證碼里有什么干擾因素,再想辦法把它呈現(xiàn)出來。如下
//設置干擾因素
//1.畫線條
for ($g=0; $g 3; $g++) {
//設置線條顏色
$line = imagecolorallocate($im, rand(50,100), rand(50,100), rand(50,100));
//輸出線條
imageline($im,rand(0,99),rand(0,19),rand(0,99),rand(0,19), $line);
}
//2.給背景加點點
for ($r=0; $r 300; $r++) {
//設置點點顏色
$point = imagecolorallocate($im, rand(20,180), rand(20,180), rand(20,180));
//輸出點點
imagesetpixel($im, rand(0,100), rand(0,30), $point);
}
imagepng($im);//輸出整個圖片
到這里,我們的驗證碼功能基本上已經(jīng)實現(xiàn)的差不多了,內(nèi)容獲取到了,橫線和點點等干擾因素也有了。如果需要添加到登錄頁面可自行發(fā)揮。
更多關于PHP相關內(nèi)容感興趣的讀者可查看本站專題:《PHP圖形與圖片操作技巧匯總》、《PHP數(shù)組(Array)操作技巧大全》、《PHP數(shù)據(jù)結(jié)構(gòu)與算法教程》、《php程序設計算法總結(jié)》、《PHP數(shù)學運算技巧總結(jié)》、《php字符串(string)用法總結(jié)》及《php常見數(shù)據(jù)庫操作技巧匯總》
希望本文所述對大家PHP程序設計有所幫助。
您可能感興趣的文章:- php7 list()、session及其他模塊的修改實例分析
- PHP7創(chuàng)建銷毀session的實例方法
- PHP 實現(xiàn)超簡單的SESSION與COOKIE登錄驗證功能示例
- PHP cookie與session會話基本用法實例分析
- 如何解決PHP獲取不到SESSION信息之一般情況
- thinkphp 5框架實現(xiàn)登陸,登出及session登陸狀態(tài)檢測功能示例
- php實現(xiàn)多站點共用session實現(xiàn)單點登錄的方法詳解
- PHP實現(xiàn)cookie跨域session共享的方法分析
- PHP使用Session實現(xiàn)上傳進度功能詳解
- PHP SESSION跨頁面?zhèn)鬟f失敗解決方案