标签:
既然上一篇文章《php上传中文文件文件名乱码问题》遇到了文件上传的问题,干脆把php上传文件时经常碰到的几个问题总结一下吧,以后用到时不用再去找了。
1 <html> 2 <head> 3 <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> 4 </head> 5 <body> 6 7 <form action="upload_file.php" method="post" 8 enctype="multipart/form-data"> 9 <label for="file">Filename:</label> 10 <input type="file" name="file" id="file" /> 11 <br /> 12 <input type="submit" name="submit" value="Submit" /> 13 </form> 14 15 </body> 16 </html>
1 <?php 2 if (($_FILES["file"]["size"] < 20000) 3 { 4 if ($_FILES["file"]["error"] > 0) 5 { 6 echo "Return Code: " . $_FILES["file"]["error"] . "<br />"; 7 } 8 else 9 { 10 echo "Upload: " . $_FILES["file"]["name"] . "<br />"; 11 echo "Type: " . $_FILES["file"]["type"] . "<br />"; 12 echo "Size: " . ($_FILES["file"]["size"] / 1024) . " Kb<br />"; 13 echo "Temp file: " . $_FILES["file"]["tmp_name"] . "<br />"; 14 15 if (file_exists("upload/" . $_FILES["file"]["name"])) 16 { 17 echo $_FILES["file"]["name"] . " already exists. "; 18 } 19 else 20 { 21 move_uploaded_file($_FILES["file"]["tmp_name"], 22 "upload/" . $_FILES["file"]["name"]); 23 echo "Stored in: " . "upload/" . $_FILES["file"]["name"]; 24 } 25 } 26 } 27 else 28 { 29 echo "Invalid file"; 30 } 31 ?>
$_FILES[‘userfile‘][‘name‘]
$_FILES[‘userfile‘][‘type‘]
$_FILES[‘userfile‘][‘size‘]
$_FILES[‘userfile‘][‘tmp_name‘]
$_FILES[‘userfile‘][‘error‘]
其中,$_FILES[‘userfile‘][‘error‘]的所有值:
UPLOAD_ERR_OK 其值为 0,没有错误发生,文件上传成功。
UPLOAD_ERR_INI_SIZE 其值为 1,上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值。
UPLOAD_ERR_FORM_SIZE 其值为 2,上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。
UPLOAD_ERR_PARTIAL 其值为 3,文件只有部分被上传。
UPLOAD_ERR_NO_FILE 其值为 4,没有文件被上传。
UPLOAD_ERR_NO_TMP_DIR 其值为 6,找不到临时文件夹。PHP 4.3.10 和 PHP 5.0.3 引进。
UPLOAD_ERR_CANT_WRITE 其值为 7,文件写入失败。PHP 5.1.0 引进。
我们知道使用$_FILES[‘userfile‘][‘type‘]判断上传文件类型是一个很不明智的做法,因为该判断依据是文件的后缀名,任何人都可以将一个mp3文件的后缀改成jpg从而伪装成图片进行上传,因此php官方建议使用php的扩展php_fileinfo来判断文件的mime,开启拓展的方法百度一下有很多,win和linux略有不同。
1 if (file_exists("./upload/" . $_FILES["file"]["name"])) 2 { 3 do{ 4 $suffix =""; 5 $suffix_length = 4; 6 $str = "0123456789abcdefghijklmnopqrstuvwxyz"; 7 $len = strlen($str)-1; 8 //文件名后追加4个随机字符 9 for($i=0 ; $i<$suffix_length; $i++){ 10 $suffix .= $str[rand(0,$len)]; 11 } 12 $upload_filename = $_FILES[‘file‘][‘name‘]; 13 $filename = substr($upload_filename,0,strrpos($upload_filename,".")).$suffix.".".substr($upload_filename,strrpos($_FILES["file"]["name"],".")+1); 14 }while(file_exists("./upload/".$filename)); 15 move_uploaded_file($_FILES["file"]["tmp_name"],"./upload/" . $filename); 16 }else{ 17 move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . $_FILES["file"]["name"]); 18 }
1 $structure = ‘./‘.date("Y").‘/‘.date("m").‘/‘.date("d").‘/‘; 2 3 4 if (!mkdir($structure, 0777, true)) { 5 die(‘Failed to create folders...‘); 6 } 7 8 move_uploaded_file($_FILES["file"]["tmp_name"],$structure . $_FILES["file"]["name"]);
1 <form action="" method="post" enctype="multipart/form-data"> 2 <p>Pictures: 3 <input type="file" name="pictures[]" /> 4 <input type="file" name="pictures[]" /> 5 <input type="file" name="pictures[]" /> 6 <input type="submit" value="Send" /> 7 </p> 8 </form>
1 <?php 2 foreach ($_FILES["pictures"]["error"] as $key => $error) { 3 if ($error == UPLOAD_ERR_OK) { 4 $tmp_name = $_FILES["pictures"]["tmp_name"][$key]; 5 $name = $_FILES["pictures"]["name"][$key]; 6 move_uploaded_file($tmp_name, "data/$name"); 7 } 8 } 9 ?>
有的情况下多文件的这种变量结构并不好用:
array(1) {
["upload"]=>array(2) {
["name"]=>array(2) {
[0]=>string(9)"file0.txt"
[1]=>string(9)"file1.txt"
}
["type"]=>array(2) {
[0]=>string(10)"text/plain"
[1]=>string(10)"text/html"
}
}
}
很多情况下我们需要的是类似这样的结构
array(1) {
["upload"]=>array(2) {
[0]=>array(2) {
["name"]=>string(9)"file0.txt"
["type"]=>string(10)"text/plain"
},
[1]=>array(2) {
["name"]=>string(9)"file1.txt"
["type"]=>string(10)"text/html"
}
}
}
使用下面的函数就能轻松转化结构
1 function diverse_array($vector) { 2 $result = array(); 3 foreach($vector as $key1 => $value1) 4 foreach($value1 as $key2 => $value2) 5 $result[$key2][$key1] = $value2; 6 return $result; 7 } 8 $upload = diverse_array($_FILES["upload"]);
首先,在表单上
<input type="hidden" name="MAX_FILE_SIZE" value="字节" />
可以限制上传文件大小(可以被绕过)。
然后在服务器上也需要调整一下配置
php.ini:
max_execution_time = 30 每个脚本运行的最长时间,单位秒
max_input_time = 60,每个脚本可以消耗的时间,单位也是秒
memory_limit = 128M,这个是脚本运行最大消耗的内存
post_max_size = 8M,表单提交最大数据为 8M,此项不是限制上传单个文件的大小,而是针对整个表单的提交数据进行限制的。
upload_max_filesize = 2M ,上载文件的最大许可大小
nginx:
1 location / { 2 root html; 3 index index.html index.htm; 4 client_max_body_size 1000m; 5 }
标签:
原文地址:http://www.cnblogs.com/hornedreaper1988/p/4254857.html