本文分为五个部分针对PHP上传文件进行分析讲解,具体内容如下
1.文件上传变量
$filename = $_FILES["myFile"]["name"];
$type = $_FILES["myFile"]["type"];
$tmp_name = $_FILES["myFile"]["tmp_name"];
$size = $_FILES["myFile"]["size"];
$error = $_FILES["myFile"]["error"];
2.将服务器上的临时文件移动到指定目录下
//2.copy($tmp_name,$destination)
copy($tmp_name,"D:/".$filename);
3.PHP.ini上传相关配置
max_execution_time = 1 设置了脚本被解析器终止之前允许的最大执行时间,单位为秒,防止程序写的不好而占尽服务器资源
max_input_time = 60 脚本解析输入数据允许的最大时间,单位为秒
max_input_nesting_level = 64 设置输入变量的嵌套深度
max_input_vars = 1000 接受多少输入的变量
memory_limit = 128M 最大单线程的独立内存使用量
4.error错误号
5.单文件上传实例
form.htmlfileUpload.PHP
$type = $fileInfo["type"];
$error = $fileInfo["error"];
$size = $fileInfo["size"];
$tmp_name = $fileInfo["tmp_name"];
$maxSize=210241024;//允许的最大值
$allowExt=array("jpeg","jpg","gif");
$flag = true;//检测是否为真实的图片类型
//判断错误号
if($error == 0){
//判断上传文件的大小
if($size>$maxSize){
exit("上传文件过大");
}
//检测文件类型
//取出文件扩展名
$ext = pathinfo($filename,PATHINFO_EXTENSION);
if(!in_array($ext,$allowExt)){
exit("非法文件类型");
}
//检测是否为真实的图片类型
if($flag){
if(@!getimagesize($tmp_name)){
exit("不是正的图片类型");
}
}
//创建目录
$path = "D:/test/";
if(!file_exists($path)){
mkdir($path,0777,true);
chmod($path,0777);
}
//确保文件名唯一,防止重名覆盖
$uniName = md5(uniqid(microtime(true),true)).".".$ext;
$destination = $path.$uniName;
if(@move_uploaded_file($tmp_name,$destination)){
echo "上传成功";
}else{
echo "上传失败";
}
}else{
switch($error){
case 1:
case 2:
case 3:
case 4:
case 6:
case 7:
case 8:
echo "上传错误";
break;
}
}
希望本文所述对大家学习PHP程序设计有所帮助。