环境:

1、wamp:php5.4.12 

2、ThinkPHP_Extend_3.1.2 中UploadFile.class.php

代码:

function upload(){

import('UploadFile.class');

$upload = new UploadFile();// 实例化上传类

$upload->maxSize  = 3145728 ;// 设置附件上传大小

$upload->allowExts  = array('jpg', 'gif', 'png', 'jpeg');// 设置附件上传类型

$upload->savePath =  './temp/';// 设置附件上传目录

if(!$upload->upload()) {// 上传错误提示错误信息

echo($upload->getErrorMsg());

}else{// 上传成功 获取上传文件信息

$info =  $upload->getUploadFileInfo();

}

// 保存表单数据 包括附件数据

echo $info[0]['savename']; // 保存上传的照片根据需要自行组装

}

问题:

1、提示“非法上传文件”

2、提示“文件上传保存错误”

分析:

UploadFile.class.php文件中打印输出文件路径名:

echo $file['tmp_name']; D:\\wamp\\tmp\\phpF95B.tmp

这个路径名异常,应该是D:\wamp\tmp\phpF95B.tmp才能正常上传文件。

深入研究:

当magic_quotes_gpc是Off的时候,由于为$_FILES数组添加了addslashes作用,出现了问题。也就在 magic_quotes_gpc是Off的PHP环境下都会出现此问题。

解决:

UploadFile.class.php文件中进行文件路径处理,类文件的bug:

public function upload($savePath ='')入口方法进行处理

if (!get_magic_quotes_gpc()) {

            $file['tmp_name'] = str_replace('\\\\', '\\', $file['tmp_name']);

            }

最终解决问题。