最新下载
热门教程
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
解决DEDEcms 出现“Upload filetype not allow”问题
时间:2015-08-29 编辑:简简单单 来源:一聚教程网
如果有同学是按某些朋友用删除代码的方法解决问题的话,建议你修正此做法,毕竟这是有很大安全风险的。而DEDE本身的安全隐患比较多,任何不安全的修改和操作都会断送掉网站的安全。
$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.a.com;D:/PHP/temp"”
然后重启WebServer,至此,问题解决。
-
上一个: JS实现自动倒计时30秒后按钮才可用
-
下一个: 应用接口之:Ajax 的简单方法
相关文章
- dedecms上传文件大小受限制如何修改 dedecms上传文件大小受限制修改方法 11-04
- dedecms防止被挂马必看安全知识 11-09
- DEDECMS调用指定顶级栏目的子栏目名称的方法 07-26
- DEDECMS调用栏目名称常用标签(子栏目 当前栏目 父栏目) 07-26
- Dedecms标签artlist调用副栏目二次开发 06-28
- dedecms实现文章列表隔行换色和随机颜色的方法 04-18