php表单文件iframe异步上传实例讲解


Posted in PHP onJuly 26, 2017

本文实例为大家分享了php表单文件iframe异步上传的具体代码,供大家参考,具体内容如下

1.表单中放置iframe元素;
2.文件上传控件内容变化的时候触发JS设置表单的action为处理文件上传的img_upload_process.php文件,并且将表单的target设置为iframe,让iframe去提交到服务器进行文件上传;
3.img_upload_process.php中处理文件上传成功后,将上传成功保存的文件路径回传给表单中隐藏域;
4.点击表单提交按钮的时,JS设置表单action为接收表单数据的form_process.php文件,表单的target设置为_self。

表单:asyn_uplaod.html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>图片异步上传</title>
</head>
<body>
<!-- application/x-www-form-urlencoded 缺省编码类型 -->
<!-- multipart/form-data 多媒体传输协议 ,方法必须是post 既可以发送文本数据,也支持二进制数据上载 -->
<form action="" method="post" enctype="multipart/form-data">
 用户名: <input type="text" name="username" /><br /> 
 上传头像: <input type="file" id="avator" name="avator" onchange="startUpload(this.form)" />

 <iframe frameborder='0' width='0' height='0' name="uploadframe"></iframe> 
 <input type="hidden" id="save_path" name="save_path" />
 <span id="loading"></span> <br /> 
 <img width='100' height='100' id='uploaded_img' /> <br />
 <input type="submit" name="submitted" value="提交" onclick="formSubmit(this.form)" />

</form>

<script>

function startUpload(formObj){
  document.getElementById('loading').innerHTML = '上传中...'; 
  formObj.action = 'img_upload_process.php'; 
  formObj.target = 'uploadframe'; 
  formObj.submit(); 
}


function formSubmit(formObj) {
 formObj.action = 'form_process.php'; 
 formObj.target = '_self';

 //清空文件上传内容,防止重复提交
 var fileObj = document.getElementById('avator') ;

 // for IE, Opera, Safari, Chrome
 if (fileObj.outerHTML) {
  fileObj.outerHTML = fileObj.outerHTML;
 } else { // FF(包括3.5)
  fileObj.value = "";
 }

 formObj.submit(); 
}

</script>

</body>
</html>

处理文件上传:img_upload_process.php

<?php
include 'Upload.class.php';

$file = $_FILES['avator'];
$upload = new Upload();//上传工具类对象


if($save_path = $upload->up($file)){//上传成功
 echo <<<STR
 <script> 
  window.parent.document.getElementById('uploaded_img').src = "$save_path";
  window.parent.document.getElementById('loading').innerHTML = '上传成功'; 
  window.parent.document.getElementById('save_path').value = "$save_path"; 
 </script>
STR;

}else{
 $error = $upload->error();
 echo <<<STR
 <script>
  window.parent.document.getElementById('uploaded_img').src = "";
  window.parent.document.getElementById('loading').innerHTML = "上传失败: $error";
 </script>
STR;

}

文件上传工具类:Upload.class.php

<?php
class Upload{
 private $path; //文件上传目录
 private $max_size; //上传文件大小限制
 private $errno; //错误信息号
 private $mime = array('image/jpeg','image/png','image/gif');//允许上传的文件类型

 /**
  * 构造函数,
  * @access public
  * @param $path string 上传的路径
  */
 public function __construct($path = './' ){
  $this->path = $path;
  $this->max_size = 1000000;
 }

 /**
  * 文件上传的方法,分目录存放文件
  * @access public
  * @param $file array 包含上传文件信息的数组
  * @return mixed 成功返回上传的文件名,失败返回false
  */
 public function up($file){
  //判断文件是否是通过 HTTP POST 上传,防止恶意欺骗
  /*
  if (! is_uploaded_file($file['tmp_name'])) {
   $this->errno = 5; //设置错误信息号为5,表示非法上传
   return false;
  }
  */

  //判断是否从浏览器端成功上传到服务器端
  if ($file['error'] == 0) {
   # 上传到临时文件夹成功,对临时文件进行处理
   //上传类型判断
   if (!in_array($file['type'], $this->mime)) {
    # 类型不对
    $this->errno = -1; 
    return false;
   }

   //判断文件大小
   if ($file['size'] > $this->max_size) {
    # 大小超出配置文件的中的上传限制
    $this->errno = -2;
    return false;
   }

   //获取存放上传文件的目录
   $sub_path = date('Ymd').'/';
   if (!is_dir($this->path . $sub_path)) {
    # 不存在该目录,创建之
    mkdir($this->path . $sub_path);
   }

   //文件重命名,由当前日期 + 随机数 + 后缀名
   $file_name = date('YmdHis').uniqid().strrchr($file['name'], '.');

   //准备就绪了,开始上传
   if (move_uploaded_file($file['tmp_name'], $this->path . $sub_path . $file_name)) {
    # 移动成功
    return $sub_path . $file_name;
   } else {
    # 移动失败
    $this->errno = -3;
    return false;
   }

  } else {
   # 上传到临时文件夹失败,根据其错误号设置错误号
   $this->errno = $file['error'];
   return false;
  }

 }

 /**
  * 多文件上传方法
  * @access public
  * @param $file array 包含上传文件信息的数组,是一个二维数组
  * @return array 成功返回上传的文件名构成的数组, ?如果有失败的则不太好处理了
  */
 public function multiUp($files){
  //在多文件上传时,上传文件信息 又是一个多维数组,如$_FILES['userfile']['name'][0],$_FILES['userfile']['name'][1]
  //我们只需要遍历该数组,得到每个上传文件的信息,依次调用up方法即可
  foreach ($files['name'] as $key => $value) {
   # code...
   $file['name'] = $files['name'][$key];
   $file['type'] = $files['type'][$key];
   $file['tmp_name'] = $files['tmp_name'][$key];
   $file['error'] = $files['error'][$key];
   $file['size'] = $files['size'][$key];
   //调用up方法,完成上传
   $filename[] = $this->up($file);
  }
  return $filename;
 }

 /**
  * 获取错误信息,根据错误号获取相应的错误提示
  * @access public
  * @return string 返回错误信息
  */
 public function error(){
  switch ($this->errno) {
   case -1:
    return '请检查你的文件类型,目前支持的类型有'.implode(',', $this->mime);
    break;
   case -2:
    return '文件超出系统规定的大小,最大不能超过'. $this->max_size;
    break;
   case -3:
    return '文件移动失败';
    break;
   case 1:
    return '上传的文件超过了 php.ini 中 upload_max_filesize 选项限制的值,其大小为'.ini_get('upload_max_filesize');
    break;
   case 2:
    return '上传文件的大小超过了 HTML 表单中 MAX_FILE_SIZE 选项指定的值,其大小为' . $_POST['MAX_FILE_SIZE'];
    break;
   case 3:
    return '文件只有部分被上传';
    break;
   case 4:
    return '没有文件被上传';
    break;
   case 5:
    return '非法上传';
    break;
   case 6:
    return '找不到临时文件夹';
    break;
   case 7:
    return '文件写入临时文件夹失败';
    break;
   default:
    return '未知错误,灵异事件';
    break;
  }
 }
}

处理表单提交:form_process.php

<?php
var_dump($_REQUEST);
var_dump($_FILES);

php表单文件iframe异步上传实例讲解

点击表单提交按钮结果:

php表单文件iframe异步上传实例讲解

代码下载:php表单文件iframe异步上传

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

PHP 相关文章推荐
php checkdate、getdate等日期时间函数操作详解
Mar 11 PHP
基于php上传图片重命名的6种解决方法的详细介绍
Apr 28 PHP
php遍历文件夹下的所有文件和子文件夹示例
Mar 20 PHP
PHP 面向对象程序设计(oop)学习笔记(一) - 抽象类、对象接口、instanceof 和契约式编程
Jun 12 PHP
PHP扩展模块memcached长连接使用方法分析
Dec 24 PHP
PHP中SESSION的注销与清除
Apr 16 PHP
PHP读取配置文件类实例(可读取ini,yaml,xml等)
Jul 28 PHP
php上传功能集后缀名判断和随机命名(强力推荐)
Sep 10 PHP
PHP中PDO连接数据库中各种DNS设置方法小结
May 13 PHP
php mysql 封装类实例代码
Sep 18 PHP
[企业公众号]升级到[企业微信]之后发送消息失败的解决方法
Jun 30 PHP
php如何计算两坐标点之间的距离
Dec 29 PHP
php实现的统计字数函数定义与使用示例
Jul 26 #PHP
PHP SFTP实现上传下载功能
Jul 26 #PHP
Windows平台实现PHP连接SQL Server2008的方法
Jul 26 #PHP
php判断str字符串是否是xml格式数据的方法示例
Jul 26 #PHP
深入理解Yii2.0乐观锁与悲观锁的原理与使用
Jul 26 #PHP
php实现微信企业号支付个人的方法详解
Jul 26 #PHP
PHP编程实现微信企业向用户付款的方法示例
Jul 26 #PHP
You might like
apache+mysql+php+ssl服务器之完全安装攻略
2006/09/05 PHP
一个完整的PHP类包含的七种语法说明
2015/06/04 PHP
php创建桌面快捷方式实现方法
2015/12/31 PHP
Laravel实现autoload方法详解
2017/05/07 PHP
javascript读取RSS数据
2007/01/20 Javascript
jquery 简短几句代码实现给元素动态添加及获取提示信息
2011/09/01 Javascript
Javacript实现颜色梯度变化和渐变的效果代码
2013/05/31 Javascript
通过js获取div的background-image属性
2013/10/15 Javascript
JS+CSS实现自适应选项卡宽度的圆角滑动门效果
2015/09/15 Javascript
jQuery form插件之ajaxForm()和ajaxSubmit()的可选参数项对象
2016/01/23 Javascript
JavaScript 栈的详解及实例代码
2017/01/22 Javascript
微信小程序网络请求wx.request详解及实例
2017/05/18 Javascript
JavaScript 通过Ajax 动态加载CheckBox复选框
2017/08/31 Javascript
JS去掉字符串末尾的标点符号及删除最后一个字符的方法
2017/10/24 Javascript
详解如何使用webpack在vue项目中写jsx语法
2017/11/08 Javascript
vue对storejs获取的数据进行处理时遇到的几种问题小结
2018/03/20 Javascript
微信小程序利用canvas 绘制幸运大转盘功能
2018/07/06 Javascript
JS实现图片上传多次上传同一张不生效的处理方法
2018/08/06 Javascript
微信小程序textarea层级过高(盖住其他元素)问题的解决办法
2019/03/04 Javascript
Vue中Table组件Select的勾选和取消勾选事件详解
2019/03/19 Javascript
nodejs分离html文件里面的js和css的方法
2019/04/09 NodeJs
微信小程序实现搜索功能并跳转搜索结果页面
2019/05/18 Javascript
基于Vue.js与WordPress Rest API构建单页应用详解
2019/09/16 Javascript
基于javascript实现移动端轮播图效果
2020/12/21 Javascript
[04:45]DOTA2上海特级锦标赛主赛事第四日RECAP
2016/03/06 DOTA
Python字符串的encode与decode研究心得乱码问题解决方法
2009/03/23 Python
Python面向对象实现一个对象调用另一个对象操作示例
2019/04/08 Python
Python 实现Serial 与STM32J进行串口通讯
2019/12/18 Python
Python 读取WAV音频文件 画频谱的实例
2020/03/14 Python
django表单中的按钮获取数据的实例分析
2020/07/31 Python
解决import tensorflow导致jupyter内核死亡的问题
2021/02/06 Python
一款基于css3麻将筛子3D翻转特效的实例教程
2014/12/31 HTML / CSS
美国婴儿用品店:Babies”R”Us
2017/10/12 全球购物
教师岗位说明书
2015/09/30 职场文书
Linux、ubuntu系统下查看显卡型号、显卡信息详解
2022/04/07 Servers
win10更新失败无限重启解决方法
2022/04/19 数码科技