今天使用代碼進行PHP產生校正碼功能的實現,發現firefox一直提示“映像.......因其本身有錯無法顯示”的問題,作者也提示了說“如果瀏覽器顯示“映像XXX因其本身有錯無法顯示”,可盡量去掉文中空格”,但把代碼中所有空格都去掉了還是不能顯示檢驗圖片。
於是深度google,大部分的解決方案也是將“
確認碼組建檔案checkNum_session.php
複製代碼 代碼如下:
Header("Content-type: image/png");
/*
* 初始化
*/
$border = 1; //是否要邊框 1要:0不要
$how = 4; //驗證碼位元
$w = $how*15; //圖片寬度
$h = 20; //圖片高度
$fontsize = 6; //字型大小
$alpha = "abcdefghijkmnopqrstuvwxyz"; //驗證碼內容1:字母
$number = "023456789"; //驗證碼內容2:數字
$randcode = ""; //驗證碼字串初始化
srand((double)microtime()*1000000); //初始化隨機數種子
$im = ImageCreate($w, $h); //建立驗證圖片
/*
* 繪製基本架構
*/
$bgcolor = ImageColorAllocate($im, 255, 255, 255); //設定背景顏色
ImageFill($im, 0, 0, $bgcolor); //填充背景色
if($border)
{
$black = ImageColorAllocate($im, 0, 0, 0); //設定邊框顏色
ImageRectangle($im, 0, 0, $w-1, $h-1, $black);//繪製邊框
}
/*
* 逐位產生隨機字元
*/
for($i=0; $i<$how; $i++)
{
$alpha_or_number = mt_rand(0, 1); //字母還是數字
$str = $alpha_or_number ? $alpha : $number;
$which = mt_rand(0, strlen($str)-1); //取哪個字元
$code = substr($str, $which, 1); //取字元
$j = !$i ? 4 : $j+15; //繪字元位置
$color3 = ImageColorAllocate($im, mt_rand(0,100), mt_rand(0,100), mt_rand(0,100)); //字元隨即顏色
ImageChar($im, $fontsize, $j, 3, $code, $color3); //繪字元
$randcode .= $code; //逐位加入驗證碼字串
}
//把驗證碼字串寫入session
session_start();
$_SESSION['authnum_session'] = $randcode;
/*
* 添加幹擾
*/
for($i=0; $i<1; $i++)//繪背景幹擾線
{
$color1 = ImageColorAllocate($im, mt_rand(0,255), mt_rand(0,255), mt_rand(0,255)); //幹擾線顏色
ImageArc($im, mt_rand(-5,$w), mt_rand(-5,$h), mt_rand(20,300), mt_rand(20,200), 55, 44, $color1); //幹擾線
}
for($i=0; $i<$how*40; $i++)//繪背景幹擾點
{
$color2 = ImageColorAllocate($im, mt_rand(0,255), mt_rand(0,255), mt_rand(0,255)); //幹擾點顏色
ImageSetPixel($im, mt_rand(0,$w), mt_rand(0,$h), $color2); //幹擾點
}
//關鍵代碼,防止出現'映像因其本身有錯無法顯示'的問題
ob_clean();
/*繪圖結束*/
Imagegif($im);
ImageDestroy($im);
/*繪圖結束*/
確認碼調用檔案sessionValidate.php
複製代碼 代碼如下:
session_start();
//在頁首先要開啟session,
//error_reporting(2047);
session_destroy();
//將session去掉,以每次都能取新的session值;
//用seesion 效果不錯,也很方便
?>
session 圖片驗證執行個體
此例為session驗證執行個體
//列印上一個session;
echo "上一個session:".$_SESSION["authnum_session"]."
";
$validate="";
if(isset($_POST["validate"])){
$validate=$_POST["validate"];
echo "您剛才輸入的是:".$_POST["validate"]."
狀態:";
if($validate!=$_SESSION["authnum_session"]){
//判斷session值與使用者輸入的驗證碼是否一致;
echo "輸入有誤";
}else{
echo "通過驗證";
}
}
/*
//列印全部session;
PrintArr($_SESSION);
function PrintArr($aArray){
echo '
';<BR>print_r($aArray);<BR>echo '';
}
*/
?>