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作的文本留言本的例子(二)
Oct 09 PHP
在字符串中把网址改成超级链接
Oct 09 PHP
PHP通过COM使用ADODB的简单例子
Dec 31 PHP
phpmyadmin 常用选项设置详解版
Mar 07 PHP
php查找字符串出现次数的方法
Dec 01 PHP
一款简单实用的php操作mysql数据库类
Dec 08 PHP
PHP处理会话函数大总结
Aug 05 PHP
php正则提取html图片(img)src地址与任意属性的方法
Feb 08 PHP
PHP实现的AES加密、解密封装类与用法示例
Aug 02 PHP
php实现二叉树中和为某一值的路径方法
Oct 14 PHP
PHP getDocNamespaces()函数讲解
Feb 03 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输出当前进程所有变量/常量/模块/函数/类的示例
2013/11/07 PHP
php类常量用法实例分析
2015/07/09 PHP
非常经典的PHP文件上传类分享
2016/05/15 PHP
PHP微信企业号开发之回调模式开启与用法示例
2017/11/25 PHP
JavaScript中常用的运算符小结
2012/01/18 Javascript
深入理解JavaScript系列(16) 闭包(Closures)
2012/04/12 Javascript
基于JS实现密码框(password)中显示文字提示功能代码
2016/05/27 Javascript
input框中的name和id的区别
2016/11/16 Javascript
浅谈js之字面量、对象字面量的访问、关键字in的用法
2016/11/20 Javascript
Angular JS 生成动态二维码的方法
2017/02/23 Javascript
在bootstrap中实现轮播图实例代码
2017/06/11 Javascript
JavaScript之事件委托实例(附原生js和jQuery代码)
2017/07/22 jQuery
vue实现点击隐藏与显示实例分享
2019/02/13 Javascript
JS 自执行函数原理及用法
2019/08/05 Javascript
浅入深出Vue之自动化路由
2019/08/06 Javascript
layer.open组件获取弹出层页面变量、函数的实例
2019/09/25 Javascript
使用vscode快速建立vue模板过程详解
2019/10/10 Javascript
vue-router 2.0 跳转之router.push()用法说明
2020/08/12 Javascript
在vue中给后台接口传的值为数组的格式代码
2020/11/12 Javascript
python编写简单爬虫资料汇总
2016/03/22 Python
python中函数传参详解
2016/07/03 Python
Python简单读写Xls格式文档的方法示例
2018/08/17 Python
详解Python logging调用Logger.info方法的处理过程
2019/02/12 Python
pyinstaller打包单个exe后无法执行错误的解决方法
2019/06/21 Python
python中bs4.BeautifulSoup的基本用法
2019/07/27 Python
Python打印不合法的文件名
2020/07/31 Python
HTML5实现移动端弹幕动画效果
2019/08/01 HTML / CSS
Amaze UI 文件选择域的示例代码
2020/08/26 HTML / CSS
美国排名第一的在线葡萄酒商店:Wine.com
2016/09/07 全球购物
开普敦通行证:Cape Town Pass
2019/07/18 全球购物
Ajax和javascript的区别
2013/07/20 面试题
顶撞老师检讨书
2014/02/07 职场文书
员工工作表现自我评价
2015/03/06 职场文书
python析构函数用法及注意事项
2021/06/22 Python
十大公认最好看的动漫:《咒术回战》在榜,《钢之炼金术师》第一
2022/03/18 日漫
SQL Server中的游标介绍
2022/05/20 SQL Server