2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > PHP文件上传操作实例详解

PHP文件上传操作实例详解

时间:2022-02-01 01:34:25

相关推荐

PHP文件上传操作实例详解

后端开发|php教程

PHP 文件上传

后端开发-php教程

本文实例分析了PHP文件上传操作。分享给大家供大家参考,具体如下:

安卓开发前端后端源码,vscode输入命令界面,ubuntu 安装音乐,tomcat 发布jar,sqlite3同步写入,公告插件,前端开发可以用多个框架吗,爬虫爬取固定的薪资,php 执行sh,丰县企业seo制作,进网站后台显示空白,介绍电影的网页模板,ace后台模板使用教程lzw

文件上传

java 在线商城 源码下载,ubuntu y480,tomcat怎么杀端口进程,r包爬虫,php调用system,沈阳运营抖音seo优化参考价lzw

发生在浏览器向服务器发出的请求中。

同城app源码,vscode 依赖库,苹果ubuntu 键盘背光,tomcat日志迁移,c sqlite 日期,dedecms首页幻灯片插件,web前端框架开发,爬虫获取ajax,php的ajax,武汉seo费用,搜索网站首页html,个人空间网页,.net 模板引擎,wap支付页面模板,经典通用网站后台管理系统源码,小程序第三方系统源码lzw

文件,对于浏览器来讲,就是表单中的一个特殊类型的数据而已。

浏览器表单中的数据,两种类型:

字符串类型(字节流编码)

文件类型(二进制编码),文件是表单数据中一部分

服务器角度:

在接受浏览器请求时,处理好表单内的数据。根据数据类型不同使用不同处理方法:

字符串类型,存储在$_POST变量中(内存)

文件型数据,存储在上传临时目录中

表单提交时,浏览器会默认的行为:

表单内的的内容都是字符串类型,即使添加了文件域,需要在form上增加属性,告知浏览器上传的不止有字符串类型数据。enctype=”multipart/form-data”

php服务器在接收到文件类型的表单数据后,将文件存储于临时目录(属于临时文件,脚本周期内有效)

; Temporary directory for HTTP uploaded files (will use system default if not; specified).; /upload-tmp-dir;upload_tmp_dir =

将临时文件持久化存储

move_uploaded_file(src_url,goa_url)

$_FILES,存储了上传文件的信息包括临时地址

错误类型:

0-1-2-3-4-6-7

0表示没有错误

1表示文件大于php的设置

; Maximum allowed size for uploaded files.; /upload-max-filesizeupload_max_filesize = 2M

2表示文件大于表单设置max_file_size

3表示文件上传不完整

4表示没有上传文件

5表示逻辑上上传了0字节的文件(空文件)

6表示没有找到临时上传目录(权限不足)

7表示文件写入失败(磁盘空间、权限)

php允许的最大上传文件数量

; Maximum number of files that can be uploaded via a single requestmax_file_uploads = 20

post存在最大值限制

一旦超过,php就不能正常处理post与file值可能为空值

; Maximum size of POST data that PHP will accept.; /post-max-sizepost_max_size = 8M

类型检测中

后缀名与mime都是浏览器提供的,需要php的扩展fileinfo完成对文件信息的检查(函数过程与面向对象)

;extension=php_fileinfo.dll

$finfo = new Finfo(FILEINFO_MIME_TYPE);$mine_type = $finfo->file($file[ mp_name]);

分子目录存储上传文件

原则:业务逻辑、文件数量、时间

创建目录 mkdir()

检查目录 is_dir()

<?phpupload($_FILES[file]);function upload($file){ if($file[error]!=0){ return false; } //3M $max_size = 3145728; if($max_sizearray(image/jpeg,image/pjpeg), .jpg=>array(image/jpeg,image/pjpeg), .jpg=>array(image/png,image/x-png), .jpg=>array(image/gif) ); //后缀 $allow_ext_list = array(.jpeg,.jpg,.jpg); $ext = strtolower(strrchr($file[ ame],.)); if(!in_array($ext,$allow_ext_list)){ echo 不支持该图片格式; return false; } //MIME $allow_mime_list = array(); foreach($allow_ext_list as $val){ $allow_mime_list = array_merge($allow_mime_list,$type_map[$val]); } //浏览器提供信息坚持 $allow_mime_list = array_unique($allow_mime_list); if(!in_array($file[ ype],$allow_mime_list)){ echo 不支持该图片格式; return false; } //php自身检查 $file_mime = new Finfo(FILEINFO_MIME_TYPE); $mime = $file_mime->file($file[ mp_name]); if(!in_array($mime,$allow_mime_list)){ echo 不支持该图片格式; return false; } //目录存储 $up_loadpath = ./; $sub_dir = date(Ymdh); if(!is_dir($up_loadpath.$sub_dir)){ mkdir($up_loadpath.$sub_dir); } $prefix = ee_; $name = uniqid($prefix,true).$ext; if(move_uploaded_file($file[ mp_name],$up_loadpath.$sub_dir.$name)){ echo 上传成功; return $name; }else{ echo 上传失败; return false; }}

更多 PHP文件上传操作实例详解相关文章请关注PHP中文网!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。