您现在的位置是:首页 > 教程 > dedecms教程dedecms教程
dedecms出现“Upload filetype not allow”的原因及解决方法
欧有皆2024-05-24 23:14:02dedecms教程已有人查阅
导读本人是在近日升级DEDE5.6以后出现这个问题的,以下说明错误原因和解决办法。如果有同学是按某些朋友用删除代码的方法解决问题的话
本人是在近日升级DEDE5.6以后出现这个问题的,以下说明错误原因和解决办法。如果有同学是按某些朋友用删除代码的方法解决问题的话,建议你修正此做法,毕竟这是有很大安全风险的。而DEDE本身的安全隐患比较多,任何不安全的修改和操作都会断送掉网站的安全。
我们可以看出,这getimagesize($$_key)这个方法,是在请求PHP临时目录的读取权限,如果d:/php/temp没有读取权限就会出现无法读取的错误。
@getimagesize($$_key);返回的值其实是False,而这里DEDE程序员简单的使用了@屏掉错误提示,并没有考虑到权限问题,造成用户无法了解真正错误原因是没有目录权限,而不是文件类型不允许。
修改办法如下:
1,在PHP.ini中添加d:/php/temp的读写权限,这一步基本上都不用操作。因为这个目录一般都是可读写的,不然任何文件都无法上传;
2, 部份虚拟主机用户,可能添加了php_admin_value open_basedir 指令,在这里,我们要求添加上临时目录的权限,如:“php_admin_value open_basedir
$imtypes = array("image/pjpeg","image/jpeg","image/gif","image/png","image/xpng","image/wbmp","image/bmp"); if(in_array(strtolower(trim(${$_key.'_type'})),$imtypes))
{
$image_dd = @getimagesize($$_key);
if (!is_array($image_dd))
{
exit('Upload filetype not allow !');
}
}
这里的$$_key,指的是上传文件的临时路径,如“d:/php/temp/aaa.tmp”。我们可以看出,这getimagesize($$_key)这个方法,是在请求PHP临时目录的读取权限,如果d:/php/temp没有读取权限就会出现无法读取的错误。
@getimagesize($$_key);返回的值其实是False,而这里DEDE程序员简单的使用了@屏掉错误提示,并没有考虑到权限问题,造成用户无法了解真正错误原因是没有目录权限,而不是文件类型不允许。
修改办法如下:
1,在PHP.ini中添加d:/php/temp的读写权限,这一步基本上都不用操作。因为这个目录一般都是可读写的,不然任何文件都无法上传;
2, 部份虚拟主机用户,可能添加了php_admin_value open_basedir 指令,在这里,我们要求添加上临时目录的权限,如:“php_admin_value open_basedir
"E:/wwwroot/www.ebingou.cn;D:/PHP/temp"”
然后重启WebServer,至此,问题解决。
本文标签:
很赞哦! ()
相关文章
随机图文
-
dede织梦typeid的标签type
织梦模板的标签typeid是用来表示栏目ID,在列表模板和档案模板中一般不需要指定,在封面模板中允许用","分开表示多个栏目;然而有时候我们发现它却不可以在channel里调用 -
dedecms织梦程序漏洞的修复解决方法
众所周之,织梦的开源程序在企业站或门户站中占有很大地位,其以自身强大功能及上手快,操作易的特点, 使得不少初学者纷纷选择此程序来搭建自己的网站站点。 -
织梦使用中怎么修改织梦提示信息对话框的内容
在织梦Dedecms中,页面跳转时都会是出现一个DEDECMS提示信息的对话框,我们可以根据自己的个人网站来修改这个提示信息标题,具体方法如下: -
织梦常用标签整理归类和说明
flag = 'h' 自定义属性值:头条[h]推荐[c] 图片[p]幻灯[f]滚动[s]跳转[j]图文[a]加粗[b]在这里aRCliST有更多的参数,可以查阅织梦的教程,用到 就几个。
留言与评论 (共有 条评论) |