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开发入门教程之面向对象
Dec 05 PHP
php防注
Jan 15 PHP
php设计模式 Command(命令模式)
Jun 26 PHP
Zend的AutoLoad机制介绍
Sep 27 PHP
PHP统计nginx访问日志中的搜索引擎抓取404链接页面路径
Jun 30 PHP
PHP遍历XML文档所有节点的方法
Mar 12 PHP
详解PHP原生DOM对象操作XML的方法
Oct 17 PHP
php+redis在实际项目中HTTP 500: Internal Server Error故障排除
Feb 05 PHP
thinkphp下MySQL数据库读写分离代码剖析
Apr 18 PHP
Yii2设置默认控制器的两种方法
May 19 PHP
Laravel源码解析之路由的使用和示例详解
Sep 27 PHP
PHP中有关长整数的一些操作教程
Sep 11 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
BBS(php &amp; mysql)完整版(一)
2006/10/09 PHP
drupal 代码实现URL重写
2011/05/04 PHP
JavaScript实现滚动栏效果的方法
2015/04/27 PHP
关于PHP开发的9条建议
2015/07/27 PHP
thinkphp,onethink和thinkox中验证码不显示的解决方法分析
2016/06/06 PHP
PHP的HTTP客户端Guzzle简单使用方法分析
2019/10/30 PHP
js使用函数绑定技术改变事件处理程序的作用域
2011/12/26 Javascript
Struts2的s:radio标签使用及用jquery添加change事件
2013/04/08 Javascript
同域jQuery(跨)iframe操作DOM(示例代码)
2013/12/13 Javascript
js图片闪动特效可以控制间隔时间如几分钟闪动一下
2014/08/12 Javascript
jQuery+css实现百度百科的页面导航效果
2014/12/16 Javascript
JS实现仿google、百度搜索框输入信息智能提示的实现方法
2015/04/20 Javascript
Javascript必知必会(四)js类型转换
2016/06/08 Javascript
javascript事件冒泡简单示例
2016/06/20 Javascript
详解在vue-cli项目中使用mockjs(请求数据删除数据)
2017/10/23 Javascript
基于angular-utils-ui-breadcrumbs使用心得(分享)
2017/11/03 Javascript
微信小程序判断页面是否从其他页面返回的实例代码
2019/07/03 Javascript
express框架中使用jwt实现验证的方法
2019/08/25 Javascript
Vue 解决在element中使用$notify在提示信息中换行问题
2020/11/11 Javascript
详解js创建对象的几种方式和对象方法
2021/03/01 Javascript
[04:42]2015国际邀请赛CDEC战队晋级之路
2015/08/13 DOTA
python连接字符串的方法小结
2015/07/13 Python
Python实现 多进程导入CSV数据到 MySQL
2017/02/26 Python
Pandas实现数据类型转换的一些小技巧汇总
2018/05/07 Python
python环形单链表的约瑟夫问题详解
2018/09/27 Python
pyqt5 使用cv2 显示图片,摄像头的实例
2019/06/27 Python
TensorFlow基本的常量、变量和运算操作详解
2020/02/03 Python
详解python中GPU版本的opencv常用方法介绍
2020/07/24 Python
超级实用的8个Python列表技巧
2020/08/24 Python
利用CSS3的特性改变文本选中时的颜色
2013/09/11 HTML / CSS
ToysRus日本官网:玩具反斗城
2018/09/08 全球购物
市场营销大学生职业规划书
2014/02/25 职场文书
小学生感恩演讲稿
2014/04/25 职场文书
消防安全主题班会
2015/08/12 职场文书
2016年社区六一儿童节活动总结
2016/04/06 职场文书
python爬虫之selenium库的安装及使用教程
2021/05/23 Python