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 相关文章推荐
如何对PHP程序中的常见漏洞进行攻击
Oct 09 PHP
简化php模板页面中分页代码的解析
Feb 06 PHP
php分页示例分享
Apr 30 PHP
PHP延迟静态绑定示例分享
Jun 22 PHP
smarty中post用法实例
Nov 28 PHP
PHP的cURL库简介及使用示例
Feb 06 PHP
PHP获取文件相对路径的方法
Feb 26 PHP
php使用PDO获取结果集的方法
Feb 16 PHP
php获取ajax的headers方法与内容实例
Dec 27 PHP
浅谈PHP中pack、unpack的详细用法
Mar 12 PHP
Laravel框架创建路由的方法详解
Sep 04 PHP
如何在PHP中生成随机数
Jun 04 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 foreach循环中使用引用的问题
2013/11/06 PHP
php sybase_fetch_array使用方法
2014/04/15 PHP
php查询mysql数据库并将结果保存到数组的方法
2015/03/18 PHP
如何利用http协议发布博客园博文评论
2015/08/03 PHP
php实现的中文分词类完整实例
2017/02/06 PHP
PHP 范围解析操作符(::)用法分析【访问静态成员和类常量】
2020/04/14 PHP
ModelDialog JavaScript模态对话框类代码
2011/04/17 Javascript
javascript随机显示背景图片的方法
2015/06/18 Javascript
jQuery进行组件开发完整实例
2015/12/15 Javascript
js与jQuery实现checkbox复选框全选/全不选的方法
2016/01/05 Javascript
Node.js编写组件的三种实现方式
2016/02/25 Javascript
JS异步文件分片断点上传的实现思路
2016/12/25 Javascript
javascript设计模式之模块模式学习笔记
2017/02/15 Javascript
jQuery实现的手风琴侧边菜单效果
2017/03/29 jQuery
vue2.0 axios前后端数据处理实例代码
2017/06/30 Javascript
浅谈react+es6+webpack的基础配置
2017/08/09 Javascript
JS实现二维数组横纵列转置的方法
2018/04/17 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
2018/11/14 Javascript
微信小程序实现页面浮动导航
2019/01/28 Javascript
Vue强制组件重新渲染的方法讨论
2020/02/03 Javascript
[33:33]完美世界DOTA2联赛PWL S2 FTD.C vs SZ 第二场 11.27
2020/11/30 DOTA
python处理Excel xlrd的简单使用
2017/09/12 Python
对tensorflow 的模型保存和调用实例讲解
2018/07/28 Python
pycharm运行出现ImportError:No module named的解决方法
2018/10/13 Python
Django中的ajax请求
2018/10/19 Python
PyTorch中Tensor的维度变换实现
2019/08/18 Python
Python 日期的转换及计算的具体使用详解
2020/01/16 Python
详解px单位html5响应式方案
2018/03/08 HTML / CSS
介绍一下Java的安全机制
2012/06/28 面试题
如何理解transaction事务的概念
2015/05/27 面试题
小学教师办公室制度
2014/02/03 职场文书
学校四群教育实施方案
2014/06/12 职场文书
2014年征兵标语
2014/06/20 职场文书
小学运动会前导词
2015/07/20 职场文书
研讨会致辞
2015/07/31 职场文书
《丑小鸭》教学反思
2016/02/19 职场文书