今天使用代碼進行PHP產生校正碼功能的實現,發現firefox一直提示“映像.......因其本身有錯無法顯示”的問題,作者也提示了說“如果瀏覽器顯示“映像XXX因其本身有錯無法顯示”,可盡量去掉文中空格”,但把代碼中所有空格都去掉了還是不能顯示檢驗圖片。於是深度google,大部分的解決方案也是將“<?”這句代碼前的空格斷行符號一切都刪掉以防止有html輸出,但這根本解決不了我的問題,後來看到有人在Header("Content-type: image/PNG");這句代碼前使用ob_clean()清除輸出,結果一試之下果然成功。現將原代碼修改後貼到下面,以備不時之需(使用方法參看原帖):
確認碼組建檔案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; //逐位加入驗證碼字串}//把驗證碼字串寫入sessionsession_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
<?phpsession_start();//在頁首先要開啟session,//error_reporting(2047);session_destroy();//將session去掉,以每次都能取新的session值;//用seesion 效果不錯,也很方便?><html><head><title>session 圖片驗證執行個體</title></head> <body> 此例為session驗證執行個體<form action="" method="post">驗證碼:<input type="text" name="validate" value="" size=10> <img src="checkNum_session.php"><br><input type="submit"></form><?php//列印上一個session;echo "上一個session:<b>".$_SESSION["authnum_session"]."</b><br>";$validate="";if(isset($_POST["validate"])){$validate=$_POST["validate"];echo "您剛才輸入的是:".$_POST["validate"]."<br>狀態:";if($validate!=$_SESSION["authnum_session"]){//判斷session值與使用者輸入的驗證碼是否一致;echo "<font color=red>輸入有誤</font>"; }else{echo "<font color=green>通過驗證</font>"; }} /*//列印全部session;PrintArr($_SESSION);function PrintArr($aArray){echo '<xmp>';print_r($aArray);echo '</xmp>';}*/?>
轉自:http://ddkangfu.blog.51cto.com/311989/608203