关于PHP上传文件的函数类库,网上有许多封装很完善,大家直接拿来用就可以。

本文章只是说下关于上传原理和简单的上传操作,老鸟就无视了哈^_^~

还有一些安全性判断比如:服务端限制能接收图片类型的文件,而客户端恶意将病毒文件的后缀名改为图片配型的文件上传。

(举例单文件上传,多文件原理还是不变,只不过多了点小技巧)

index.html

  1. <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2. <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
  3. <head>
  4. <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
  5. <title>upload files</title>
  6. </head>
  7. <body>
  8.  
  9. <form action="upload.php" enctype="multipart/form-data" method="post">
  10. <input type="hidden" name="MAX_FILE_SIZE" value="10000" />
  11. 上传文件:<input type="file" name="file"/>
  12. <input type="submit" value="上传" />
  13. </form>
  14. </body>
  15. </html>

1、Form标签enctype属性

表单中enctype="multipart/form-data"是用于设置表单的MIME编码。
默认情况,这个编码格式是application/x-www-form-urlencoded,不能用于文件上传;
只有使用了multipart/form-data且提交方式为Post才能完整的传递文件数据。

2、MAX_FILE_SIZE 隐藏字段

MAX_FILE_SIZE 隐藏字段(单位为字节)必须放在文件输入字段之前,其值为接收文件的最大尺寸。这是对浏览器的一个建议,PHP 也会检查此项。
在浏览器端可以简单绕过此设置,因此不要指望用此特性来阻挡大文件。(不过鉴于友好性最好还是在表单中加上此项目,因为它可以避免用户在花时间等待上传大文件之后才发现文件过大上传失败的麻烦。)

upload.php

  1. <?php
  2. print_r($_FILES);
  3. ?>

我们可以看到:

  1. Array
  2. (
  3. [file] => Array
  4. (
  5. [name] => 照片文件.jpg
  6. [type] => image/jpeg
  7. [tmp_name] => F:\wamp\tmp\php41BB.tmp
  8. [error] => 0
  9. [size] => 73886
  10. )
  11.  
  12. )

3、全局变量 $_FILES的应用

  $_FILES['file']['name']  为上传文件的原文件名

  $_FILES['file']['type']  为上传文件的 MIME 类型

  $_FILES['file']['size']  已上传文件的大小,单位为字节

  $_FILES['file']['tmp_name']  文件被上传后在服务端储存的临时文件名()

  $_FILES['file']['error']  文件上传的错误代码

4、默认情况下,上传文件会保存在服务端的临时文件夹中,其目录在php.ini中设置

php.ini与文件上传有关的一些常用设置:

file_uploads ;  是否允许通过HTTP上传文件的开关。默认为ON即是开

upload_tmp_dir ;  文件上传至服务器上存储临时文件的地方,如果没指定就会用系统默认的临时文件夹

upload_max_filesize;  即允许上传文件大小的最大值。默认为2M

post_max_size;  指通过表单POST给PHP的所能接收的最大值,包括表单里的所有值。默认为8M

下面是对单文件上传的完整代码,因为是随想随写的,可能逻辑嵌套的有点乱,懂原理最重要。

  1. <?php
  2.  
  3. //取得上传文件信息
  4. $fileName=$_FILES['file']['name'];
  5. $fileType=$_FILES['file']['type'];
  6. $fileError=$_FILES['file']['error'];
  7. $fileSize=$_FILES['file']['size'];
  8. $tempName=$_FILES['file']['tmp_name'];//临时文件名
  9.  
  10. //定义上传文件类型
  11. $typeList = array("image/jpeg","image/jpg","image/png","image/gif"); //定义允许的类型
  12.  
  13. if($fileError>0){
  14. //上传文件错误编号判断
  15. switch ($fileError) {
  16. case 1:
  17. $message="上传的文件超过了php.ini 中 upload_max_filesize 选项限制的值。";
  18. break;
  19. case 2:
  20. $message="上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值。";
  21. break;
  22. case 3:
  23. $message="文件只有部分被上传。";
  24. break;
  25. case 4:
  26. $message="没有文件被上传。";
  27. break;
  28. case 6:
  29. $message="找不到临时文件夹。";
  30. break;
  31. case 7:
  32. $message="文件写入失败";
  33. break;
  34. case 8:
  35. $message="由于PHP的扩展程序中断了文件上传";
  36. break;
  37. }
  38.  
  39. exit("文件上传失败:".$message);
  40.  
  41. }
  42. if(!is_uploaded_file($tempName)){
  43. //判断是否是POST上传过来的文件
  44. exit("不是通过HTTP POST方式上传上来的");
  45. }else{
  46. if(!in_array($fileType, $typeList)){
  47. exit("上传的文件不是指定类型");
  48. }else{
  49. if(!getimagesize($tempName)){
  50. //避免用户上传恶意文件,如把病毒文件扩展名改为图片格式
  51. exit("上传的文件不是图片");
  52. }
  53. }
  54. if($fileSize>100000){
  55. //对特定表单的上传文件限制大小
  56. exit("上传文件超出限制大小");
  57. }else{
  58. //避免上传文件的中文名乱码
  59. $fileName=iconv("UTF-8", "GBK", $fileName);//把iconv抓取到的字符编码从utf-8转为gbk输出
  60. $fileName=str_replace(".", time().".", $fileName);//在图片名称后加入时间戳,避免重名文件覆盖
  61. if(move_uploaded_file($tempName, "uploads/".$fileName)){
  62. echo "上传文件成功!";
  63. }else{
  64. echo "上传文件失败";
  65. }
  66. }
  67.  
  68. }
  69.  
  70. ?>

5、关于php上传文件的一些常用函数:(具体用法就不贴出来了,自己看API文档吧 ^_^)

file_exists  检查文件或目录是否存在

is_uploaded_file    判断文件是否是通过 HTTP POST 上传的

move_uploaded_file    将上传的文件移动到新位置

is_writable   判断给定的文件名是否可写

iconv  字符编码互转

str_replace  字符串替换(更改文件名,防重名)

getimagesize  检查是否为图片文件(其他类型的文件就算后缀名改了也能被检测到)

PHP上传原理及操作实现的更多相关文章

  1. Python + Selenium + AutoIt 模拟键盘实现另存为、上传、下载操作详解

    前言 在web页面中,可以使用selenium的定位方式来识别元素,从而来实现页面中的自动化,但对于页面中弹出的文件选择框,selenium就实现不了了,所以就需引用AutoIt工具来实现. Auto ...

  2. Spring Boot 文件上传原理

    首先我们要知道什么是Spring Boot,这里简单说一下,Spring Boot可以看作是一个框架中的框架--->集成了各种框架,像security.jpa.data.cloud等等,它无须关 ...

  3. php文件上传原理详解(含源码)

    1.文件上传原理 将客户端的文件上传到服务器,再将服务器的临时文件上传到指定目录 2.客户端配置 提交表单 表单的发送方式为post 添加enctype="multipart/form-da ...

  4. 补习系列(11)-springboot 文件上传原理

    目录 一.文件上传原理 二.springboot 文件机制 临时文件 定制配置 三.示例代码 A. 单文件上传 B. 多文件上传 C. 文件上传异常 D. Bean 配置 四.文件下载 小结 一.文件 ...

  5. Java Web文件上传原理分析(不借助开源fileupload上传jar包)

    Java Web文件上传原理分析(不借助开源fileupload上传jar包) 博客分类: Java Web   最近在面试IBM时,面试官突然问到:如果让你自己实现一个文件上传,你的代码要如何写,不 ...

  6. HTTP文件上传原理

    前言 对于这块知识点,我一直都是模糊的,不是非常清楚的.在平时的工作中,遇到上传的问题,也没有深入的去研究过,也都是直接用别人封装好的类来完成自己的工作.某一天,看了本书,说到这个知识点,一脸茫然,觉 ...

  7. 【Selenium04篇】python+selenium实现Web自动化:文件上传,Cookie操作,调用 JavaScript,窗口截图

    一.前言 最近问我自动化的人确实有点多,个人突发奇想:想从0开始讲解python+selenium实现Web自动化测试,请关注博客持续更新! 这是python+selenium实现Web自动化第四篇博 ...

  8. 【C#公共帮助类】FTPClientHelper帮助类,实现文件上传,目录操作,下载等动作

    关于本文档的说明 本文档使用Socket通信方式来实现ftp文件的上传下载等命令的执行 欢迎传播分享,必须保持原作者的信息,但禁止将该文档直接用于商业盈利. 本人自从几年前走上编程之路,一直致力于收集 ...

  9. PHP文件上传和文件操作案例

    <?php /* *文件配置变量$dirname是目录名称 */ session_start(); $dirname = 'upload'; $fileClass = new fileClass ...

随机推荐

  1. 2. 知识图谱-命名实体识别(NER)详解

    1. 通俗易懂解释知识图谱(Knowledge Graph) 2. 知识图谱-命名实体识别(NER)详解 3. 哈工大LTP解析 1. 前言 在解了知识图谱的全貌之后,我们现在慢慢的开始深入的学习知识 ...

  2. Android ViewPage的使用(一)

    ViewPage是一个简单的页面切换组件,左右滑动的话,有效果,和ListView一样 也需要配合适配器(PagerAdapter)来使用. 先来个效果图吧 先随便创建3个view页面,用于放到 Vi ...

  3. Grunt经常使用插件及演示样例说明

    下述给出了经常使用Grunt插件,并列举了部分插件演示样例: 插件名称 说明 Github地址 grunt-contrib-clean 清空文件和目录 https://github.com/grunt ...

  4. bzoj1103【POI2007】大都市meg

    1103: [POI2007]大都市meg Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1544  Solved: 776 [Submit][St ...

  5. 老项目Xcode5.1编译器错误

    老项目编译器错误html, body {overflow-x: initial !important;}html { font-size: 14px; } body { margin: 0px; pa ...

  6. hexo静态博客的安装及应用实践记录

    1. 必须要安装 nodejs,git 2. 安装hexo node install -g hexo 3. npm源的问题使在安装时有卡住的问题而导致无法安装,则需要更改npm的源 npm confi ...

  7. pip修改国内源

    Linux在~/.pip/pip.conf文件中添加或修改, windows不存在该目录,在当前用户目录下创建pip.ini(例如 C:\Users\bin\pip\pip.ini): [global ...

  8. IIS 日志分析

    查看哪个IP访问量大,访问了什么地址,大可以看到攻击者IP: select c-ip,count(c-ip) AS allcount,cs-uri-stem,cs-uri-query,cs(User- ...

  9. 大数据处理-Bitmap

    MapReduce是一种编程模型,用于大规模数据集(大于1TB)的并行运算.概念"Map(映射)"和"Reduce(归约)" Bit-map空间压缩和快速排序去 ...

  10. PCL点云特征描述与提取(2)

    点特征直方图(PFH)描述子 正如点特征表示法所示,表面法线和曲率估计是某个点周围的几何特征基本表示法.虽然计算非常快速容易,但是无法获得太多信息,因为它们只使用很少的几个参数值来近似表示一个点的k邻 ...