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

softyun3年前cms教程108

本人是在近日升级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联动方式二级变一级的方法,现在就来说一下如何修改文件,找到infolink.lib.php。以下代码都注掉/*  $sontype = ( ($househx % 500 != 0)...

DedeCms教程:友情链接插件使用说明

织梦dedecms友情链接插件使用说明 织梦系统内置里很多对建站非常有益的插件,友情链接是最深受广大站长朋友欢迎和使用的插件之一。下面以DedeCMSV5.7为例,带着一起来熟悉这个插件。GIF图...

dedecms自定义表单后台显示时间格式错误的解决方法

今天教给大家一些织梦dedecms自定义表单后台显示时间格式错误的解决办法,比较简单,希望可以帮助到你。在制作dedecms企业模板的时候 很多客户都需要制作一个在线订购功能!仔细的朋友就会发现使用的...

有关dede静态模板类dede:foreach的使用

有关dede静态模板类dede:foreach的使用刚刚接触织梦dedecms,就从基础看起,希望大家不要见笑,多多鼓励啊 呵呵。在测试的时候发现静态模板类里面的 。{dede:foreach arr...

织梦channel栏目导航标签currentstyle鼠标点击高亮变色方法

dedecms织梦channel子栏目导航标签currentstyle鼠标点击高亮变色加class样式的方法<style> .red2{color:red;} </style>...

【Channelartlist 标记 使用实例】-DedeCMS模板制作使用实例教程(10)

【Channelartlist 标记】用于获取当前频道的下级栏目的内容列表。该标记在封面模板 包括主页中的经常被用到,具体用法见下面实例。    除了宏标记外,channelArtlist 是唯一一个...