-
PHP文件上传(用全局数组$_FILES实现)
本篇文章主要讲述了用PHP中的全局数组$_FILES去实现文件上传,具有一定参考价值,感兴趣的朋友可以了解一下。
这里使用PHP的全局数组$_FILES来实现文件上传:
$_FILES["file"]["name"] - 被上传文件的名称
$_FILES["file"]["type"] - 被上传文件的类型
$_FILES["file"]["size"] - 被上传文件的大小,以字节计
$_FILES["file"]["tmp_name"] - 存储在服务器的文件的临时副本的名称
$_FILES["file"]["error"] - 由文件上传导致的错误代码
HTML代码:
- <form action="upload_file.php" method="post" enctype="multipart/form-data">
- <label for="file">Filename:</label>
- <input type="file" name="file" id="file" /><br />
- <input type="submit" name="submit" value="Submit" /></form>
PHP代码:
- if (!emptyempty($_FILES)) {
- // 限制文件大小
- $file_size = $_FILES["file"]["size"]; // 限制2M大小
- if ($file_size > 1024 * 1024 * 2) { echo '文件大小超过限制'; exit;
- }
- // 限制文件上传类型
- $file_type = $_FILES["file"]["type"]; $file_type_arr = ['image/jpg', 'image/jpeg', 'image/png', 'image/pjpeg', 'image/gif']; if (!in_array($file_type, $file_type_arr)) { echo '上传文件类型错误'; exit;
- }
- // 文件上传到服务器临时文件夹之后的文件名
- $tem_name = $_FILES['file']['tmp_name']; // 取得文件后缀名
- $file_fix = explode('.', $_FILES['file']['name'])[1] ? explode('.', $_FILES['file']['name'])[1] : 'png'; // 文件重命名,这里自动生成一个不重复的名字,方便使用
- $name = md5(uniqid(md5(microtime(true)), true)) . '.' . $file_fix; // 要存放文件的目录定义,这里按日期分开存储
- $file_dir = dirname(__FILE__) . '/upload/' . date('Ymd') . '/'; // 检测要存放文件的目录是否存在,不存在则创建
- if (!is_dir($file_dir)) { mkdir($file_dir, 0755, true);
- } // 移动文件到指定目录下
- @ move_uploaded_file($tem_name, $file_dir . $name);
- echo '上传成功'; exit;
- } else { echo '文件上传失败'; exit;
- }
出处:http://www.phpfensi.com/php/20200322/12855.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式