dede验证码不显示,dede图集后台上传图片报错 提示红色FILEID错误的处理办法

dede图集后台上传图片报错 提示红色FILEID错误的处理办法

2013-12-15 14:24 来源:温州视线  点击:175次

  今天发布图片集时,上传图片提示FILEID:X错误,缩略图显示为红色Error,前几天还正常的,可以确定是这几天修改了系统文件造成的,dede图集后台上传图片报错,提示红色FILEID错误的处理办法。

dede图集后台上传图片报错处理
dedecms图集后台上传图片报错处理

  仔细检查是UTF-8版本BOM格式造成的,检查dedecms系统文件include/common.inc.php和/data/common.inc.php的文件格式,用dreamweaver打开以上文件检查,ctrl+j (菜单里的-->修改->页面属性) 打开编码查看,去掉上图中红框里“包括unicode签名bom”前面的勾,保存,替换原来文件,问题解决。


后台验证码不显示:服务器gd库加载了,验证码不显示,也是这个bom的事情。同样的方法试一下。



  UTF-8编码的朋友,注意将格式调整为UTF-8 无 BOM格式,GBK编码的朋友,注意将格式调整为ANSI(使用NotePad++,菜单栏有一格式菜单,打开即可调整文件格式,当然也可以选择DW,Editeplus 云云)

  对菜鸟,非常重要必须要记住的一条,如果语言编码为UTF-8,绝对不能用记事本打开修改保存任何系统文件,否则出现莫名其妙的问题会不知所措。



------------------------------------------------------------------------------------------------

其他办法:

某日,某使用DeDe CMS v5.5的网站在后台上传图片时出现如下错误: 
作为web生手的我很是迷茫。印象里之前并没有做什么改动,于是百思不得其解。Google、百度、DeDe官网搜索了一大圈,发现有这个问题的人不少,但是没有一个给出解决的办法。只好自己试着分析分析…… 
找到提示出错的相关js文件: 
/dede/handlers.js 
发现有这么一段: 

复制代码
代码如下:

function uploadSuccess(file, serverData) { 
try { 
var progress = new FileProgress(file, this.customSettings.upload_target); 
if (serverData.substring(0, 7) === "FILEID:") { 
addImage("swfupload.php?dopost=thumbnail&id=" + serverData.substring(7), serverData.substring(7)); 
progress.setStatus("获取缩略图..."); 
progress.toggleCancel(false); 
} else { 
addImage("img/error.gif", 0); 
progress.setStatus("有错误!"); 
progress.toggleCancel(false); 
alert(serverData); 

} catch (ex) { 
this.debug(ex); 



其中: 

复制代码
代码如下:

if (serverData.substring(0, 7) === "FILEID:") 

这句的判断为假导致如上图的问题。 
查看serverData的值没有发现什么异常,但是判断始终为假 
问题就出在serverData.substring(0, 7) 始终都不等于"FILEID:" 
调整了截取边界也一样有错,于是乎,请来了HttpAnalyzer一看,哦,原来如此: 
虽然这么看着没什么问题DEDE教程-ASQQ8.NET 
但实际问题在这: 
前面多了三个字节:ef bb bf 
大致一找原来这是utf-8的bom问题,是修改文件时在文件头自动加入的这三个字节导致的连锁反应 
但是那么多文件要找出是哪个文件的问题倒是有点头大……网络资源网-ASQQ8.NET 
后来找到一篇文章《转两篇 移除PHP中BOM的方法》按照其中给出的清除BOM的代码解决了这个问题 
代码如下: 

复制代码
代码如下:

<?php 
//remove the utf-8 boms 
//by magicbug at gmail dot com 
if (isset($_GET['dir'])){ //config the basedir 
$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 "; 
echo checkBOM("$basedir/$file")." 
"; 
}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.</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); 

?>保存为a.php,放在网站根目录访问下就可以了。 
ps:如果在访问a.php的时候报错如: 
PHP Fatal error: Allowed memory size of 134217728 bytes exhausted 
那就试用下面的修改版检查出有bom的文件自己修改吧 
<?php 
//remove the utf-8 boms 
//by magicbug at gmail dot com 
if (isset($_GET['dir'])){ //config the basedir 
$basedir=$_GET['dir']; 
}else{ 
$basedir = '.'; 

$auto = 1; 
checkdir($basedir); 
echo ("
<font color=green>completed!</font>
"); 
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"); 

else 

$dirname = $basedir."/".$file; 
checkdir($dirname); 



closedir($dh); 


function checkBOM ($filename) { 
global $auto; 
$contents = file_get_contents($filename,NULL,NULL,0,10); 
$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); 
echo ($filename."--------"."<font color=red>BOM found</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); 

?> 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

北方的刀郎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值