PHP+iFrame实现页面无需刷新的异步文件上传


Posted in PHP onSeptember 16, 2014

本文实例讲述了PHP+iFrame实现页面无需刷新的异步文件上传,是非常实用的常见技巧。分享给大家供大家参考。具体分析如下:

说到iframe,现在用它的人是越来越少了,并且很多人都相信它应该被AJAX所取代,的确如此,因为AJAX太出色了。

不过有一种情况的实现我还是选择了iframe,这就是本文要说的文件的异步上传,感兴趣的可以试试,如果用原生的AJAX来实现应该是要复杂的多。

先来给初学者补补基础知识:

1. 在iframe标签一般会指定其name特性以于标识;
2. 在form表单中通过action(目标地址)和target(目标窗口,默认为_self)来确定提交的目的地;
3. 将form中的target指向iframe的name,则可将表单提交到了隐藏框架iframe中;
4. iframe里的内容实际上也是一个页面,其中的js里的parent对象指代父页面,即嵌入iframe的页面;
5. PHP中用move_uploaded_file()函数来实现文件上传,$_FILES数组存储有上传文件的相关信息。

本文实现的是一个用户选择了头像文件后立刻上传并显示在页面上的例子,废话不多说,思路是这样的:

1. 在表单中嵌入一个iframe,设定好name特性值;
2. 在选择文件上传的控件的值改变时触发一个js函数,该函数将表单提交至iframe,而iframe内嵌的页面用来处理文件上传;
3. 在iframe中完成了文件上传之后,在js中通过parent来操作父页面,在特定的标签内显示图片,并将图片的保存地址赋给一个隐藏域;
4. 回到原来的页面,现在既完成了文件的上传,也在隐藏域内记录了文件的路径,整个过程没有刷新页面;
5. 最后用户只需提交原来的页面时重置表单的action和target属性的值即可。

下面是效果截图和实现的代码:

PHP+iFrame实现页面无需刷新的异步文件上传

upload.php页面如下:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> 
<title>iFrame异步文件上传</title> 
</head> 
<body> 
<h1>iFrame异步文件上传</h1> 
<form method="post" enctype="multipart/form-data"> 
  用户名: <input type="text" name="username" /><br /> 
  上传头像: <input type="file" name="uploadphoto" onchange="startUpload(this.form)" /> 
  <iframe style="display:none" mce_style="display:none" name="uploadframe"></iframe> 
  <input type="hidden" id="photo" name="photo" value="" /> 
  <div id="displayphoto"></div> 
  <input type="submit" name="submitted" value="提交" onclick="formSubmit(this.form)" /> 
</form> 
<?php  
//页面提交后显示相关信息 
if (isset($_POST['submitted'])) { 
  $html = '<hr /><p>上传成功!</p>'; 
  $html .= '<p>用户名:'.htmlspecialchars($_POST['username']).'</p>'; 
  $html .= '<p>头像地址:'.htmlspecialchars($_POST['photo']).'</p>'; 
  $html .= '<div><img src="'.htmlspecialchars($_POST['photo']).'" mce_src="'.htmlspecialchars($_POST['photo']).'" /></div><hr />'; 
  echo $html; 
} 
?> 
</body> 
</html> 
<mce:script type="text/javascript"><!-- 
//选择了文件后开始异步上传 
function startUpload(oForm) { 
  document.getElementById('displayphoto').innerHTML = 'Loading...'; 
  oForm.action = 'proceedupload.php'; 
  oForm.target = 'uploadframe'; 
  oForm.submit(); 
} 
//整个页面的提交 
function formSubmit(oForm) { 
  oForm.action = document.URL; 
  oForm.target = '_self'; 
  oForm.submit(); 
} 
// --></mce:script>

proceedupload.php页面如下:

<?php 
//这里仅以特定图片格式举例,本应动态获取 
$url = 'upload/img' . time() . '.jpg'; 
if (move_uploaded_file($_FILES['uploadphoto']['tmp_name'], $url)) { 
  //删除之前的图片 
  $_POST['photo'] !== '' && unlink($_POST['photo']); 
?> 
<html> 
<head> 
<body onLoad="doneLoading(parent, '<?=$url?>')"> 
</body> 
</html> 
<mce:script type="text/javascript"><!-- 
//在页面上显示刚刚上传成功的图像 
function doneLoading(theFrame, url) { 
  var oDiv = theFrame.document.getElementById('displayphoto'); 
  oDiv.innerHTML = '<img src="' + url + '" mce_src="' + url + '" alt="上传头像" />'; 
  theFrame.document.getElementById('photo').value = url; 
} 
// --></mce:script> 
<?php 
}
?>

感兴趣的朋友可以测试运行一下本文实例,相信本文所述对大家PHP程序设计的学习有一定的借鉴价值。

PHP 相关文章推荐
教你如何把一篇文章按要求分段
Oct 09 PHP
php基础知识:函数基础知识
Dec 13 PHP
PHP中cookies使用指南
Mar 16 PHP
PHP 魔术函数使用说明
May 14 PHP
Windows下编译PHP5.4和xdebug全记录
Apr 03 PHP
使用PHP编写发红包程序
Jul 22 PHP
Yii2中YiiBase自动加载类、引用文件方法分析(autoload)
Jul 25 PHP
php微信开发接入
Aug 27 PHP
浅析PHP中的闭包和匿名函数
Dec 25 PHP
phpMyAdmin通过密码漏洞留后门文件
Nov 20 PHP
PHP7导出Excel报ERR_EMPTY_RESPONSE解决方法
Apr 16 PHP
PHP使用Session实现上传进度功能详解
Aug 06 PHP
PHP使用静态方法的几个注意事项
Sep 16 #PHP
PHP处理JSON字符串key缺少双引号的解决方法
Sep 16 #PHP
php中使用PHPExcel读写excel(xls)文件的方法
Sep 15 #PHP
PHP常量使用的几个需要注意的地方(谨慎使用PHP中的常量)
Sep 12 #PHP
php修改指定文件后缀的方法
Sep 11 #PHP
MyEclipse常用配置图文教程
Sep 11 #PHP
Linux下PHP安装mcrypt扩展模块笔记
Sep 10 #PHP
You might like
PHP中数组的三种排序方法分享
2012/05/07 PHP
php根据日期显示所在星座的方法
2015/07/13 PHP
PHP处理CSV表格文件的常用操作方法总结
2016/07/01 PHP
总结PHP删除字符串最后一个字符的三种方法
2016/08/30 PHP
php中引用符号(&amp;)的使用详细介绍
2016/12/06 PHP
基于jquery的has()方法以及与find()方法以及filter()方法的区别详解
2013/04/26 Javascript
json数据处理技巧(字段带空格、增加字段、排序等等)
2013/06/14 Javascript
当前页禁止复制粘贴截屏代码小集
2013/07/24 Javascript
JavaScript控制网页平滑滚动到指定元素位置的方法
2015/04/17 Javascript
JS动画效果打开、关闭层的实现方法
2015/05/09 Javascript
javascript表单验证大全
2015/08/12 Javascript
js中javascript:void(0) 真正含义
2020/11/05 Javascript
Javascript HTML5 Canvas实现的一个画板
2020/04/12 Javascript
微信小程序 教程之WXSS
2016/10/18 Javascript
Vue实现图片轮播组件思路及实例解析
2020/05/11 Javascript
vue实现户籍管理系统
2020/05/29 Javascript
浅谈在vue-cli3项目中解决动态引入图片img404的问题
2020/08/04 Javascript
vue组件添加事件@click.native操作
2020/10/30 Javascript
[49:05]Newbee vs TNC 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
python中zip和unzip数据的方法
2015/05/27 Python
Python中的集合类型知识讲解
2015/08/19 Python
python实现微信跳一跳辅助工具步骤详解
2018/01/04 Python
对tf.reduce_sum tensorflow维度上的操作详解
2018/07/26 Python
深入理解python中sort()与sorted()的区别
2018/08/29 Python
Python实现的KMeans聚类算法实例分析
2018/12/29 Python
python分布式计算dispy的使用详解
2019/12/22 Python
python 等差数列末项计算方式
2020/05/03 Python
Python爬虫获取豆瓣电影并写入excel
2020/07/31 Python
CSS Grid布局教程之浏览器开启CSS Grid Layout汇总
2014/12/30 HTML / CSS
安全宣传标语
2014/06/10 职场文书
门面房租房协议书
2014/08/20 职场文书
2014年医院十一国庆节活动方案
2014/09/15 职场文书
戒毒悔改检讨书
2014/09/21 职场文书
MBA推荐信怎么写
2015/03/25 职场文书
世界十大动漫制作公司排行榜,迪士尼上榜,第二是美国代表性文化符
2022/03/18 欧美动漫
DE1107机评
2022/04/05 无线电