$_FILES:经由 HTTP POST 文件上传而提交至脚本的变量,类似于旧数组$HTTP_POST_FILES 数组(依然有效,但反对使用)详细信息可参阅 POST方法上传
$_FILES数组内容如下:
$_FILES['myFile']['name'] 客户端文件的原名称
$_FILES['myFile']['type'] 文件的 MIME类型,需要浏览器提供该信息的支持,例如"image/gif"
$_FILES['myFile']['size'] 已上传文件的大小,单位为字节
$_FILES['myFile']['tmp_name'] 文件被上传后在服务端储存的临时文件名,一般是系统默认,可以在php.ini的upload_tmp_dir指定,但用 putenv() 函数设置是不起作用的
$_FILES['myFile']['error'] 和该文件上传相关的错误代码,['error'] 是在 PHP 4.2.0版本中增加的,下面是它的说明:(它们在PHP3.0以后成了常量)
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;没有文件被上传, 值:5; 上传文件大小为0
注:
1. 文件被上传结束后,默认地被存储在了临时目录中,这时必须将它从临时目录中删除或移动到其它地方,如果没有,则会被删除。也就是不管是否上传成功,脚本执行完后临时目录里的文件肯定会被删除。所以在删除之前要用PHP的copy() 函数将它复制到其它位置,此时,才算完成了上传文件过程。
2. 在 PHP 4.1.0 版本以前该数组的名称为 $HTTP_POST_FILES,它并不像$_FILES 一样是自动全局变量。PHP 3 不支持 $HTTP_POST_FILES数组。
3. 用form上传文件时,一定要加上属性内容enctype="multipart/form-data",否则用$_FILES[filename]获取文件信息时会报异常。
官方错误提示代码:
1 php 2 3 class UploadException extends Exception 4 { 5 public function __construct($code) { 6 $message = $this->codeToMessage($code); 7 parent::__construct($message, $code); 8 } 9 10 private function codeToMessage($code) 11 { 12 switch ($code) { 13 case UPLOAD_ERR_INI_SIZE: 14 $message = "The uploaded file exceeds the upload_max_filesize directive in php.ini"; 15 break; 16 case UPLOAD_ERR_FORM_SIZE: 17 $message = "The uploaded file exceeds the MAX_FILE_SIZE directive that was specified in the HTML form"; 18 break; 19 case UPLOAD_ERR_PARTIAL: 20 $message = "The uploaded file was only partially uploaded"; 21 break; 22 case UPLOAD_ERR_NO_FILE: 23 $message = "No file was uploaded"; 24 break; 25 case UPLOAD_ERR_NO_TMP_DIR: 26 $message = "Missing a temporary folder"; 27 break; 28 case UPLOAD_ERR_CANT_WRITE: 29 $message = "Failed to write file to disk"; 30 break; 31 case UPLOAD_ERR_EXTENSION: 32 $message = "File upload stopped by extension"; 33 break; 34 35 default: 36 $message = "Unknown upload error"; 37 break; 38 } 39 return $message; 40 } 41 } 42 43 // Use 44 if ($_FILES['file']['error'] === UPLOAD_ERR_OK) { 45 //uploading successfully done 46 } else { 47 throw new UploadException($_FILES['file']['error']); 48 } 49 ?>
无刷新上传文件:
HTML部分
1 <form name="uploadFrom" id="uploadFrom" action="gtEditUpfile.php" method="post" target="tarframe" enctype="multipart/form-data"> 2 上传文件:<inputclass="upload_file" type="file" name="upfile"> 3 form> 4 <iframe src="" width="0" height="0" style="display:none;" name="tarframe">iframe> 5 <span id="lResult">span>
JS部分
1 $(function(){ 2 $(".upload_file").change(function(){ 3 $("#uploadFrom").submit(); 4 }); 5 }); 6 function stopSend(str){ 7 $("#lResult").text(""); 8 $("#lResult").text(str); 9 }
表单提交的接收数据页gtEditUpfile.php
1 php //*连接数据库 2 $file=$_FILES['upfile']; 3 $dir="gtfile/";//文件上传目录 4 $filename=$file['name'];//客户端原文件名称,用于数据库保存文件名称 5 $file['name'] = iconv('UTF-8','GBK', $file['name']);//转换格式,以免出现中文乱码情况 6 //上传目录是否存在同名文件,避免覆盖 7 if(file_exists($dir.$file['name'])){ 8 echo "";//调用iframe父窗口的js 函数 9 }else{ 10 //另外可以对上传文件$file['size']、$file['type']分别对应文件类型、大小进行校验 11 $sql="select*from tb_table";//查看数据库中是否存在该文件信息,如果存在请先删除以免数据库中垃圾数据堆积 12 $query=mysql_query($sql); 13 if(mysql_num_rows($query)>0){ 14 echo "";//调用iframe父窗口的js 函数 15 }else{ 16 //上传文件 17 if(move_uploaded_file($file['tmp_name'],$dir.$file['name'])){ 18 $sql="SQL语句";//数据库保存修改等数据处理 19 if(mysql_query($sql)){ 20 echo ""; 21 }else{ 22 echo ""; 23 } 24 }else{ 25 echo ""; 26 } 27 } 28 } 29 ?>