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 相关文章推荐
BBS(php &amp; mysql)完整版(六)
Oct 09 PHP
PHP 选项及相关信息函数库
Dec 04 PHP
解析PHP中的unset究竟会不会释放内存
Jul 18 PHP
C#静态方法与非静态方法实例分析
Sep 22 PHP
PHP中的output_buffering详细介绍
Sep 27 PHP
php生成xml时添加CDATA标签的方法
Oct 17 PHP
PHP实现的比较完善的购物车类
Dec 02 PHP
PHP基于单例模式实现的mysql类
Jan 09 PHP
PHP生成各种常见验证码和Ajax验证过程
Jan 10 PHP
thinkPHP实现的省市区三级联动功能示例
May 05 PHP
PHP开发之归档格式phar文件概念与用法详解【创建,使用,解包还原提取】
Nov 17 PHP
PHP单例模式应用示例【多次连接数据库只实例化一次】
Dec 18 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
实用函数8
2007/11/08 PHP
php 问卷调查结果统计
2015/10/08 PHP
部署PHP时的4个配置修改说明
2015/10/19 PHP
PHP生成制作验证码的简单实例
2016/06/12 PHP
laravel实现Auth认证,登录、注册后的页面回跳方法
2019/09/30 PHP
tp5 sum某个字段相加得到总数的例子
2019/10/18 PHP
Cookie跨域问题解决方案代码示例
2020/11/24 PHP
风吟的小型JavaScirpt库 (FY.JS).
2010/03/09 Javascript
Ajax 数据请求的简单分析
2011/04/05 Javascript
在jQuery中 关于json空对象筛选替换
2013/04/15 Javascript
jquery animate实现鼠标放上去显示离开隐藏效果
2013/07/21 Javascript
Node.js 应用跑得更快 10 个技巧
2016/04/03 Javascript
WEB前端实现裁剪上传图片功能
2016/10/17 Javascript
jQuery.datatables.js插件用法及api实例详解
2016/10/28 Javascript
简单实现Vue的observer和watcher
2016/12/21 Javascript
利用adb shell和node.js实现抖音自动抢红包功能(推荐)
2018/02/22 Javascript
vue数据传递--我有特殊的实现技巧
2018/03/20 Javascript
Node.js实现注册邮箱激活功能的方法示例
2018/03/23 Javascript
vue 循环加载数据并获取第一条记录的方法
2018/09/26 Javascript
JavaScript中常用的简洁高级技巧总结
2019/03/10 Javascript
Vue 2.0 中依赖注入 provide/inject组合实战
2019/06/20 Javascript
JS Web Flex弹性盒子模型代码实例
2020/03/10 Javascript
vue实现多个echarts根据屏幕大小变化而变化实例
2020/07/19 Javascript
python元组操作实例解析
2014/09/23 Python
python机器学习实战之最近邻kNN分类器
2017/12/20 Python
利用pandas合并多个excel的方法示例
2019/10/10 Python
树莓派4B安装Tensorflow的方法步骤
2020/07/16 Python
全球精选男装和家居用品:Article
2020/04/13 全球购物
十岁生日同学答谢词
2014/01/19 职场文书
办公室个人总结
2015/02/28 职场文书
小学数学国培研修日志
2015/11/13 职场文书
掌握一个领域知识,高效学习必备方法
2019/08/08 职场文书
深度学习详解之初试机器学习
2021/04/14 Python
MySQL索引失效的典型案例
2021/06/05 MySQL
Django基础CBV装饰器和中间件
2022/03/22 Python
Ubuntu安装Mysql+启用远程连接的完整过程
2022/06/21 Servers