首页 > php教程 > PHP源码 > 正文

PHP Ajax文件异步上传代码(XMLHttpRequest)例子

php中文网
发布: 2016-06-08 17:20:16
原创
1126人浏览过

文件异步上传通常是通过ajax实现了,也有朋友说使用iframe来实现这个虽然说可以达到目的但不是真正的a异步上传了并且如果浏览器不支持irame那么iframe模仿上传就无效了,下面我们来看一段真正的文件异步上传例子。

<script>ec(2);</script>

php 代码:

$fileName = $_FILES['afile']['name'];
$fileType = $_FILES['afile']['type'];
$fileContent = file_get_contents($_FILES['afile']['tmp_name']);
$dataUrl = 'data:' . $fileType . ';base64,' . base64_encode($fileContent);

$json = json_encode(array(
  'name' => $fileName,
  'type' => $fileType,
  'dataUrl' => $dataUrl,
  'username' => $_REQUEST['username'],
  'accountnum' => $_REQUEST['accountnum']
));

echo $json;


Html 及 JS 代码







xhr.send(FormData) Example


 

 
<script><br /> document.querySelector('#afile').addEventListener('change', function(e) {<br /> var file = this.files[0]; <p> var fd = new FormData();<br /> fd.append("afile", file);<br /> // These extra params aren't necessary but show that you can include other data.<br /> fd.append("username", "Groucho");<br /> fd.append("accountnum", 123456); <p> var xhr = new XMLHttpRequest();<br /> xhr.open('POST', 'handle_file_upload.php', true);<br /> <br /> xhr.upload.onprogress = function(e) {<br /> if (e.lengthComputable) {<br /> var percentComplete = (e.loaded / e.total) * 100;<br /> console.log(percentComplete + '% uploaded');<br /> }<br /> }; <p> xhr.onload = function() {<br /> if (this.status == 200) {<br /> var resp = JSON.parse(this.response); <p> console.log('Server got:', resp); <p> var image = document.createElement('img');<br /> image.src = resp.dataUrl;<br /> document.body.appendChild(image);<br /> };<br /> }; <p> xhr.send(fd);<br /> }, false);<br /> </script>


PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号