文件上传,判断文件错误类型

HTML代码上传文件:

<form action="doAction.php" method="post" enctype="multipart/form-data">
  <input type="hidden" name="MAX_FILE_SIZE" value="51200" />
  请选择上传文件:<input type="file" name="myFile" /><br />
  <input type="submit" value="上传" />

 

doAction.php文件代码:

<meta charset="utf-8">
<?php
//files
//print_r($_FILES);

$filename=$_FILES['myFile']['name'];
$type=$_FILES['myFile']['type'];
$tmp_name=$_FILES['myFile']['tmp_name'];
$error=$_FILES['myFile']['error'];
$size=$_FILES['myFile']['size'];

//判断下错误信息
if($error==UPLOAD_ERR_OK) {
	//需要判断下文件是否是通过HTTP POST方式上传
	//is_uploaded_file($tmp_name,$destination);
	//$destination="uploads/".$filename;
	$destination="uploads/".$filename;
	if(is_uploaded_file($tmp_name)) {
		if(move_uploaded_file($tmp_name,$destination)) {
			$mes="文件上传成功";
		}else {
			$mes="文件移动失败";
		}
	}else {
		$mes="文件不是通过HTTP POST方式上传上来的";
	}
	
}else {
	switch($error) {
		case 1:
			$mes="超过了配置文件上传文件的大小";  //  UPLOAD_ERR_INI_SIZE
			break;
		case 2:
			$mes="超过了表单设置上传文件的大小";  //  UPLOAD_ERR_FORM_SIZE
			break;
		case 3:
			$mes="文件部分被上传";  //  UPLOAD_ERR_PARTIAL
			break;
		case 4:
			$mes="没有文件被上传";  //  UPLOAD_ERR_NO_FILE
			break;
		case 6:
			$mes="没有找到临时目录";  //  UPLOAD_ERR_NO_TMP_DIR
			break;
		case 7:
			$mes="文件不可写";  //UPLOAD_ERR_CANT_WRITE
			break;
		case 8:
			$mes="由于扩展文件中断了文件上传";  // UPLOAD_ERR_EXTENSION
			break;
	}
}
echo $mes;

//服务器端进行的配置  是在配置环境中php.ini中的配置
//file_uploads = On  支持通过HTTP POST方式上传文件
//;upload_tmp_dir =   临时文件保存目录
//upload_max_filesize = 2M  默认值是2M,上传的最大大小是2M
//post_max_size = 8M  表单以POST方式发送数据的最大值,默认8M

//客户端进行配置
//<input type="hidden" name="MAX_FILE_SIZE" value="1024" />  这里就是case 2判断是否错误的类型
//<input type="file" name="myFile" accept="文件的MIME类型,..."/>

 但是需要注意的是:<input type="hidden" name="MAX_FILE_SIZE" value="1024" />在客户端限制的文件大小,懂程序的人来说,这些只要打开F12调试工具,稍微修改就大小就没用了,所以限制文件以及大小必须在服务器上进行限制。

posted @ 2015-01-24 11:40  todaytoday  阅读(878)  评论(0编辑  收藏  举报