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将时间差转换为字符串提示
Sep 07 PHP
PHP调用VC编写的COM组件实例
Mar 29 PHP
PHP实现连接设备、通讯和发送命令的方法
Oct 13 PHP
PHP中使用GD库绘制折线图 折线统计图的绘制方法
Nov 09 PHP
WordPress开发中的get_post_custom()函数使用解析
Jan 04 PHP
PHP搭建大文件切割分块上传功能示例
Jan 04 PHP
php 中的closure用法详解
Jun 12 PHP
Laravel中的Auth模块详解
Aug 17 PHP
PHP实现的折半查询算法示例
Oct 09 PHP
Laravel框架处理用户的请求操作详解
Dec 20 PHP
tp5.1 框架数据库高级查询技巧实例总结
May 25 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获取当前网址url并替换参数或网址的方法
2010/06/06 PHP
解析php二分法查找数组是否包含某一元素
2013/05/23 PHP
PHP设计模式概论【概念、分类、原则等】
2020/05/01 PHP
javascript不同页面传值的改进版
2008/09/30 Javascript
我遇到的参数传递中 双引号单引号嵌套问题
2010/02/11 Javascript
javascript 二维数组的实现与应用
2010/03/16 Javascript
dreamweaver 安装Jquery智能提示
2011/04/02 Javascript
jquery方法+js一般方法+js面向对象方法实现拖拽效果
2012/08/30 Javascript
jquery插件之信息弹出框showInfoDialog(成功/错误/警告/通知/背景遮罩)
2013/01/09 Javascript
使用 Node.js 做 Function Test实现方法
2013/10/25 Javascript
javascript对象的相关操作小结
2016/05/16 Javascript
Node.js + Redis Sorted Set实现任务队列
2016/09/19 Javascript
Vue获取DOM元素样式和样式更改示例
2017/03/07 Javascript
ES6中的Promise代码详解
2017/10/09 Javascript
浅谈在vue项目中如何定义全局变量和全局函数
2017/10/24 Javascript
express+mockjs实现模拟后台数据发送功能
2018/01/07 Javascript
在小程序开发中使用npm的方法
2018/10/17 Javascript
js实现贪吃蛇小游戏
2019/10/29 Javascript
[01:24]DOTA2上海特锦赛OG战队抵达 专车接机入驻总统套房
2016/02/23 DOTA
Python多线程threading和multiprocessing模块实例解析
2018/01/29 Python
pandas的排序和排名的具体使用
2019/07/31 Python
python构造函数init实例方法解析
2020/01/19 Python
PyTorch中的C++扩展实现
2020/04/02 Python
Python如何执行系统命令
2020/09/23 Python
Opencv+Python识别PCB板图片的步骤
2021/01/07 Python
CSS3 制作旋转的大风车(充满童年回忆)
2013/01/30 HTML / CSS
美国办公用品购物网站:Quill.com
2016/09/01 全球购物
Zooplus罗马尼亚:宠物食品和配件
2019/11/02 全球购物
面向对象概念面试题(.NET)
2016/11/04 面试题
环境日宣传活动总结
2014/07/09 职场文书
2015年班级工作总结范文
2015/04/03 职场文书
高中语文教学反思范文
2016/02/16 职场文书
2019年个人工作总结范文(3篇)
2019/08/27 职场文书
基于JavaScript实现省市联动效果
2021/06/22 Javascript
pandas数值排序的实现实例
2021/07/25 Python
python实现简单的三子棋游戏
2022/04/28 Python