PHP 圖像處理與SESSION制作?針對這個問題,這篇文章詳細(xì)介紹了相對應(yīng)的分析和解答,希望可以幫助更多想解決這個問題的小伙伴找到更簡單易行的方法。
成都創(chuàng)新互聯(lián)公司專業(yè)為企業(yè)提供路橋網(wǎng)站建設(shè)、路橋做網(wǎng)站、路橋網(wǎng)站設(shè)計、路橋網(wǎng)站制作等企業(yè)網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計與制作、路橋企業(yè)網(wǎng)站模板建站服務(wù),十年路橋做網(wǎng)站經(jīng)驗,不只是建網(wǎng)站,更提供有價值的思路和整體網(wǎng)絡(luò)服務(wù)。驗證碼的實(shí)現(xiàn)
首先我們要清楚,無論是做什么東西,在做之前一定要有思路,譬如這個驗證碼里他有些什么,為了實(shí)現(xiàn)它我們該做些什么,怎么樣去做。
這里我例舉出幾個點(diǎn)。
1.驗證碼肯定要有內(nèi)容。
2.驗證碼里肯定要有干擾信息,就譬如,線條干擾和點(diǎn)點(diǎn)干擾。
那么為了實(shí)現(xiàn)他們我們該如何做呢?
第一步,創(chuàng)建一個名為captcha.php的文件
在里面輸入
這個時候,驗證碼的一些基本東西我們都完成了,定義了驗證碼的寬高,背景色驗證碼內(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; //設(shè)置x軸與y軸的坐標(biāo) $x = $i*(100/4) + rand(5,15); $y = rand(5,10); //設(shè)置驗證碼內(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;在這里我們設(shè)置了$i的變量不能大于四,然后用他乘以(100/4),保證他的的值不會大過100,再加上rand函數(shù)里隨機(jī)抽取5-15里的數(shù)值,使其的x軸坐標(biāo)范圍保證在(5-90)之間,y軸的坐標(biāo)保證在(5-10)之間,使其大概率的保證了內(nèi)容顯示的范圍居中
第三步,設(shè)置干擾因素
我們要明白,在驗證碼里有什么干擾因素,再想辦法把它呈現(xiàn)出來。如下
//設(shè)置干擾因素 //1.畫線條 for ($g=0; $g < 3; $g++) { //設(shè)置線條顏色 $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.給背景加點(diǎn)點(diǎn) for ($r=0; $r < 300; $r++) { //設(shè)置點(diǎn)點(diǎn)顏色 $point = imagecolorallocate($im, rand(20,180), rand(20,180), rand(20,180)); //輸出點(diǎn)點(diǎn) imagesetpixel($im, rand(0,100), rand(0,30), $point); } imagepng($im);//輸出整個圖片關(guān)于PHP 圖像處理與SESSION制作問題的解答就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,如果你還有很多疑惑沒有解開,可以關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道了解更多相關(guān)知識。
分享題目:PHP圖像處理與SESSION制作-創(chuàng)新互聯(lián)
文章位置:http://weahome.cn/article/deosod.html