php文件上传实验总结,53 PHP文件处理(六)文件上传--总结---细说php

前台表单设计,表单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 Uploads

shopname:

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 "不是一个上传文件"; }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值