DEDE出现“Upload filetype not allow”的原因及解决办法

softyun3年前cms教程60

本人是在近日升级DEDE5.6以后出现这个问题的,以下说明错误原因和解决办法。

如果有同学是按某些朋友用删除代码的方法解决问题的话,建议你修正此做法,毕竟这是有很大安全风险的。而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/a;D:/PHP/temp"”

然后重启WebServer,至此,问题解决。

免责声明:本文内容来自用户上传并发布,站点仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。请核实广告和内容真实性,谨慎使用。

相关文章

DedeCms教程:DedeCMS站点高级安全策略(Linux篇)

更改纪录: 2012-06-06:增加Nginx服务器的配置 在Linux环境下搭建安装DedeCMS本篇不再具体说明,大家可以点击文档《Linux下安装DedeCMS及安全设置》来查看安装和...

DEDECMS频道管理---网站栏目管理

此功能用于为网站增加栏目,俗称“分类”栏目的概念:比如建立一个体育网站,需要将网站分为:球类、田径类、跳水类。则可以分别建立三个顶级栏目:球类、田径类、跳水类其中球类又分为篮球、足球、排球。那么可以在...

如何在DedeCms 标记中运行PHP

教大家如何在织梦DedeCms 标记中运行PHP :打开 pub_dedetag.php 找到 function AssignSysTag() 在 for函数结束的地方,即是在 CODE:  这个地方...

dedecms如何修改友情链接flink模板

大家一起学习下,dedecms如何修改友情链接flink模板,有一定的参考价值,感兴趣的小伙伴尝试下织梦DEDECMS模板的友情链接标签flink主要是用于获取友情链接,其包括了诸多功能,例如分类、申...

dede:hotwords调用格式修改办法

今天给大家教一下dede:hotwords调用格式的修改方法,希望对你有帮助我们在用到织梦热门关键词调用的时候,使用织梦热门关键词调用标签:{dede:hotwords num='3'/} 这样调用出...

admin5复制文章自动加上版权的功能

模板中加入以下代码<script type="text/javascript">document.body.oncopy = function () { setTimeout( funct...