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将整个网站生成HTML纯静态网页的方法总结
Feb 05 PHP
PHP中替换换行符的几种方法小结
Oct 15 PHP
jquery+php+ajax显示上传进度的多图片上传并生成缩略图代码
Oct 15 PHP
thinkphp特殊标签用法概述
Nov 24 PHP
PHP中把数据库查询结果输出为json格式简单实例
Apr 09 PHP
PHP-FPM之Chroot执行环境详解
Aug 03 PHP
php限制文件下载速度的代码
Oct 20 PHP
ThinkPHP3.2.1图片验证码实现方法
Aug 19 PHP
PHP命名空间namespace用法实例分析
Sep 27 PHP
Ajax中的JSON格式与php传输过程全面解析
Nov 14 PHP
PHP开发API接口签名生成及验证操作示例
May 27 PHP
PHP 超级全局变量相关总结
Jun 30 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
phpstudy隐藏index.php的方法
2020/09/21 PHP
css3实现背景模糊的三种方式
2021/03/09 HTML / CSS
ExtJS 入门
2010/10/29 Javascript
js 操作select和option常用代码整理
2012/12/13 Javascript
使用Jquery实现点击文字后变成文本框且可修改
2013/09/21 Javascript
javascript创建createXmlHttpRequest对象示例代码
2014/02/10 Javascript
Koa2微信公众号开发之消息管理
2018/05/16 Javascript
js使用文档就绪函数动态改变页面内容示例【innerHTML、innerText】
2019/11/07 Javascript
javaScript中indexOf用法技巧
2019/11/26 Javascript
vue实现数据控制视图的原理解析
2020/01/07 Javascript
vue通过过滤器实现数据格式化
2020/07/20 Javascript
ant design vue中日期选择框混合时间选择器的用法说明
2020/10/27 Javascript
[07:12]2014DOTA2西雅图国际邀请赛 黑马Liquid专题采访
2014/07/12 DOTA
玩转python爬虫之URLError异常处理
2016/02/17 Python
python基于隐马尔可夫模型实现中文拼音输入
2016/04/01 Python
Python中int()函数的用法浅析
2017/10/17 Python
Anaconda入门使用总结
2018/04/05 Python
Python函数中不定长参数的写法
2019/02/13 Python
python字符串替换re.sub()实例解析
2020/02/09 Python
解决matplotlib.pyplot在Jupyter notebook中不显示图像问题
2020/04/22 Python
python模拟哔哩哔哩滑块登入验证的实现
2020/04/24 Python
python实现斗地主分牌洗牌
2020/06/22 Python
增大python字体的方法步骤
2020/07/05 Python
python获取系统内存占用信息的实例方法
2020/07/17 Python
python中not、and和or的优先级与详细用法介绍
2020/11/03 Python
Django启动时找不到mysqlclient问题解决方案
2020/11/11 Python
详解移动端Html5页面中1px边框的几种解决方法
2018/07/24 HTML / CSS
波兰电子产品购物网站:Vobis
2019/05/26 全球购物
Nordgreen台湾官网:极简北欧设计手表
2019/08/21 全球购物
职工运动会邀请函
2014/01/19 职场文书
商场促销活动方案
2014/02/08 职场文书
爱心捐书活动总结
2014/07/05 职场文书
教师自我剖析材料(群众路线)
2014/09/29 职场文书
学校师德师风整改措施
2014/10/27 职场文书
MySQL创建高性能索引的全步骤
2021/05/02 MySQL
js之ajax文件上传
2021/05/13 Javascript