前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >php 下 html5 XHR2 + FormData + File API 上传文件操作实例分析

php 下 html5 XHR2 + FormData + File API 上传文件操作实例分析

作者头像
砸漏
发布2020-10-20 09:55:59
8560
发布2020-10-20 09:55:59
举报
文章被收录于专栏:恩蓝脚本恩蓝脚本

本文实例讲述了php 下 html5 XHR2 + FormData + File API 上传文件操作。分享给大家供大家参考,具体如下:

FormData的作用:

FormData对象可以帮助我们自动的打包表单数据,通过XMLHttpRequest的send()方法来提交表单。当然FormData也可以动态的append数据。FormData的最大优点就是我们可以异步上传一个二进制文件。

例1如下:

代码语言:javascript
复制
<!DOCTYPE HTML 
<html lang="zh-CN" 
<head 
  <meta charset="UTF-8" 
  <title </title 
</head 
<body 
  <form method="post" id="myForm" onsubmit="return post();" 
    用户名<input type="text" name="uname" / 
    密码<input type="password" name="upwd" / 
    邮箱<input type="text" name="uemail" / 
    <input type="submit" name="submit" value="提交" / 
  </form 
</body 
<script type="text/javascript" 
function post() {
  var myForm = document.getElementById("myForm");
  //FormData既可以从表单读取数据,也可以动态append(键,值)添加
  var fd = new FormData(myForm);

  var xhr = new XMLHttpRequest();
  xhr.onreadystatechange = function () {
    if (xhr.readyState == 4) {
      alert(this.responseText);
    }
  };
  xhr.open("post", "post.php", true);
  xhr.send(fd);
  return false;
}
</script 
</html 

File API

使用HTML5 DOM新增的File API,现在可以让网页要求用户选择本地文件,并且读取这些文件的信息了。

通过File API,我们可以在用户选取一个或者多个文件之后,访问到代表了所选文件的一个或多个File对象,这些对象被包含在一个FileList对象中。

代码语言:javascript
复制
<!DOCTYPE HTML 
<html lang="zh-CN" 
<head 
  <meta charset="UTF-8" 
  <title </title 
</head 
<body 
  <form method="post" id="myForm" 
    <input type="file" name="file" id="upfile" / 
    <input type="submit" name="submit" value="提交" / 
  </form 
</body 
<script type="text/javascript" 
  var upfile = document.getElementById("upfile");
  upfile.onchange = function() {
    var file = this.files[0];
    alert("文件名:" + file.name + "\r\n" + "大小:" + file.size + "\r\n");
  };
</script 
</html 

我们通过FormData + File API 上传文件

代码语言:javascript
复制
<!DOCTYPE HTML 
<html lang="zh-CN" 
<head 
  <meta charset="UTF-8" 
  <title </title 
</head 
<body 
  <form method="post" id="myForm" 
    <input type="file" name="file" id="upfile" / 
    <input type="submit" name="submit" value="提交" / 
  </form 
</body 
<script type="text/javascript" 
  var myForm = document.getElementById("myForm");
  var upfile = document.getElementById("upfile");

  myForm.onsubmit = function() {
    //我们创建一个FormData对象
    var fd = new FormData();
    var file = upfile.files[0];
    //把文件添加到FormData对象中
    fd.append("file", file);

    var xhr = new XMLHttpRequest();
    xhr.onreadystatechange = function () {
      if (xhr.readyState == 4) {
        alert(this.responseText);
      }
    };
    xhr.open("post", "upfile.php", true);
    //发送FormData对象
    xhr.send(fd);
    return false;
  };
</script 
</html 

upfile.php代码如下:

代码语言:javascript
复制
<?php
$uploadDir = './upload/';
if(!file_exists($uploadDir)) {
  @mkdir($uploadDir, 0777, true);
}
$uploadFile = $uploadDir . basename($_FILES['file']['name']);
if(move_uploaded_file($_FILES['file']['tmp_name'], $uploadFile)) {
  echo "OK";
} else {
  echo "NO";
}

使用对象URL来显示你所选择的图片

通过window.URL.createObjectURL()和 window.URL.revokeObjectURL()两个DOM方法。

这两个方法创建简单的URL字符串对象,用于指向任何 DOM File 对象数据,包括用户电脑中的本地文件。

代码语言:javascript
复制
<!DOCTYPE HTML 
<html lang="zh-CN" 
<head 
  <meta charset="UTF-8" 
  <title </title 
</head 
<body 
  <form method="post" id="myForm" 
    <input type="file" name="file" id="upfile" / 
    <input type="submit" name="submit" value="提交" / 
  </form 
</body 
<script type="text/javascript" 
  var myForm = document.getElementById("myForm");
  var upfile = document.getElementById("upfile");

  upfile.onchange = function() {
    //创建一个img标签
    var img = document.createElement("img");
    //通过file对象创建对象URL
    img.src = window.URL.createObjectURL(this.files[0]);
    img.height = 60;
    img.onload = function() {
      //释放对象URL
      window.URL.revokeObjectURL(this.src);
    };
    document.body.appendChild(img);
  };

  myForm.onsubmit = function() {
    //我们创建一个FormData对象
    var fd = new FormData();
    var file = upfile.files[0];
    //把文件添加到FormData对象中
    fd.append("file", file);

    var xhr = new XMLHttpRequest();
    xhr.onreadystatechange = function () {
      if (xhr.readyState == 4) {
        alert(this.responseText);
      }
    };
    xhr.open("post", "upfile.php", true);
    //发送FormData对象
    xhr.send(fd);
    return false;
  };
</script 
</html 

更多关于PHP相关内容感兴趣的读者可查看本站专题:《php文件操作总结》、《PHP目录操作技巧汇总》、《PHP常用遍历算法与技巧总结》、《PHP数据结构与算法教程》、《php程序设计算法总结》及《PHP网络编程技巧总结》

希望本文所述对大家PHP程序设计有所帮助。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-09-11 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档