首先來看下,在網上搜索出來的解決方案有如下幾條:
1、修改一下評論表單,然后重新提交就可以了這個方法我確實第一次試了,管用,但是后面就不行了,具體是為什么我在后面會講
2、空間不支持GD庫,讓服務商解決一下
3、去掉<?php后面的空格,和?>前面的空格
4、由編碼引起的
5、由BOM頭引起的
再運行,看下 /e/showkey/index.php 文件
我們知道當A頁面include B頁面的時候,A頁面可以直接使用B頁面里面的函數和變量,當B頁面include C頁面的時候,A頁面即使沒有include C頁面,但是include B頁面,也同樣能在A頁面中使用C頁面里的函數和變量,發現connect.php頁面引用了config.php,用NotePad++打開e/class/config.php頁面,發現config.php頁面并不是無BOM的UTF-8編碼格式,而是帶了BOM的,忽然想到,之前使用了記事本打開并修改過參數的,就是這個時候記事本默認添加了BOM頭,使用NotePad++將config.php將其轉換成無BOM的文件然后上傳,刷新一下,OK!驗證碼出來了!真是一個小BOM浪費了半天的時間。
現在來說一下如何快速判斷是什么原因不顯示驗證碼
1、GD庫沒有打開
一般的虛擬主機都會將GD庫打開的,如果GD庫沒有打開,那么訪問http://你的域名/e/showkey/index.php就會出現一堆亂碼,可以告知空間提供商讓他們幫助開啟,如果是自己的主機,那么打開php.ini找到extension=php_gd2.dll將前面的“;”號去掉,重啟APACHE或IIS就可以,以前的PHP版本是extension=php_gd.dll。或者你可以將以下代碼另存為php文件傳到你空間里,如果有GD標題就說明開啟了GD庫。
-------------------------
<?php
phpinfo();
?>
-------------------------
如果訪問http://你的域名/e/showkey/index.php,顯示的不是亂碼,是紅叉,那么直接跳到第二步
2、批量去掉BOM頭代碼
將以下代碼保存為PHP文件并放置根目錄下運行,則可以批量去掉BOM頭
-------------------------
<?php
if (isset($_GET['dir'])){ //設置文件目錄
$basedir=$_GET['dir'];
}else{
$basedir = '.';
}
$auto = 1;
checkdir($basedir);
function checkdir($basedir){
if ($dh = opendir($basedir)) {
while (($file = readdir($dh)) !== false) {
if ($file != '.' && $file != '..'){
if (!is_dir($basedir."/".$file)) {
echo "filename: $basedir/$file ".checkBOM("$basedir/$file")." <br>";
}else{
$dirname = $basedir."/".$file;
checkdir($dirname);
}
}
}
closedir($dh);
}
}
function checkBOM ($filename) {
global $auto;
$contents = file_get_contents($filename);
$charset[1] = substr($contents, 0, 1);
$charset[2] = substr($contents, 1, 1);
$charset[3] = substr($contents, 2, 1);
if (ord($charset[1]) == 239 && ord($charset[2]) == 187 && ord($charset[3]) == 191) {
if ($auto == 1) {
$rest = substr($contents, 3);
rewrite ($filename, $rest);
return ("<font color=red>BOM found, automatically removed._<a href=http://www.yeetech.com>http://www.yeetech.com</a></font>");
} else {
return ("<font color=red>BOM found.</font>");
}
}
else return ("BOM Not Found.");
}
function rewrite ($filename, $data) {
$filenum = fopen($filename, "w");
flock($filenum, LOCK_EX);
fwrite($filenum, $data);
fclose($filenum);
}
?>
-------------------
運行之后,我們來看頁面,如下
拉動,右側滾動條,直至看到紅色字樣,則表示有的文件包含了bom,此時,我們把文件下載下來,然后用dw打開,存儲為UTF-8編碼,然后上傳至服務器,重新運行 bom.php 在看測試結果,如果沒有紅色字樣,那么此時,驗證碼應該可以正常顯示了。
站長提示:我們經常會改的文件有以下文件:
config.php connect.php t_functions.php user.php等,修改完之后,注意把這些文件存儲為utf-8模式,并取消bom簽名!
新聞熱點
疑難解答