前台表单设计,表单view.html,提交给upload.php
一.表单view.html
php配置文件和上传文件有关选项,注意几点:
php.ini
file_uploads=on
upload_max_filesize=2M 此值最大不超过服务器内存
upload_tmp_dir=c:/uploads 到时要拷贝出来
post_max_size=25M 要大于upload_max_filesize
2.表单需要注意几点:
1.如果有文件上传操作必须用post方法;图片要用类型file;如有文件上传enctype="multipart/form-data”
File Uploadsshopname:
shopprice:
shopnum :
shoppic:
二.php处理上传数据
注意以下几点:
有表单,有文件,需要分开些;
$_post接收表单数据;$_file接收文件
//step 1 使用$_FILES['pic']["error"] 检查错误
if($_FILES["pic"]["error"] > 0){
switch($_FILES["pic"]["error"]) {
case 1:
echo "上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值
";
break;
case 2:
echo "上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值";
break;
case 3:
echo "文件只有部分被上传";
break;
case 4:
echo "没有文件被上传";
break;
default:
echo "末知错误";
}
exit;
}
$maxsize=5000000; //50k
//step 2 使用$_FILES["pic"]["size"] 限制大小 单位字节 2M=2000000
if($_FILES["pic"]["size"] > $maxsize ) { echo "上传的文件太大,不能超过{$maxsize}字节"; exit; } //step 3 使用$_FILES["pic"]["type"]或是文件的扩展名 限制类型 MIME image/gif image/png gif png jpg /* list($dl, $xl) = explode("/", $_FILES["pic"]["type"]); if($dl!="image"){ echo "请上传一个图片,不充许其它类型文件"; exit; } */ $allowtype=array("png", "gif", "jpg", "jpeg"); $arr=explode(".", $_FILES["pic"]["name"]); $hz=$arr[count($arr)-1]; if(!in_array($hz, $allowtype)){ echo "这是不充许的类型"; exit; } //step 4 将上传后的文件名改名 $filepath="./uploads/"; $randname=date("Y").date("m").date("d").date("H").date("i").date("s").rand(100, 999).".".$hz; //将临时位置的文件移动到指定的目录上即可 if(is_uploaded_file($_FILES["pic"]["tmp_name"])){ if(move_uploaded_file($_FILES["pic"]["tmp_name"], $filepath.$randname)){ echo "上传成功"; }else{ echo "上传失败"; } }else{ echo "不是一个上传文件"; }