PHP產生驗證碼時“映像因其本身有錯無法顯示”的解決方案_php技巧

來源:互聯網
上載者:User

今天使用代碼進行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; //逐位加入驗證碼字串
}
//把驗證碼字串寫入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
複製代碼 代碼如下:

<span style="font-size:14px;"><?php
session_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>';
}
*/
?></span>

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.