phpajax实现文件上传进度
时间:2021-01-13
来源:互联网
标签:
这篇文章主要介绍了php ajax实现文件上传进度条的相关资料,需要的朋友可以参考下
本实例是关于php文件上传时进度条的实现,主要采用ajax技术,另外还运用了html5,有需要的朋友可以研究一下。
本实例有两个文件:
upload_form.html:
<!DOCTYPE html>
<html>
<head>
<script>
function _(el){
return document.getElementById(el);
}
function uploadFile(){
var file = _("file1").files[0];
// alert(file.name+" | "+file.size+" | "+file.type);
var formdata = new FormData();
formdata.append("file1", file);
var ajax = new XMLHttpRequest();
ajax.upload.addEventListener("progress", progressHandler, false);
ajax.addEventListener("load", completeHandler, false);
ajax.addEventListener("error", errorHandler, false);
ajax.addEventListener("abort", abortHandler, false);
ajax.open("POST", "file_upload_parser.php");
ajax.send(formdata);
}
function progressHandler(event){
_("loaded_n_total").innerHTML = "Uploaded "+event.loaded+" bytes of "+event.total;
var percent = (event.loaded / event.total) * 100;
_("progressBar").value = Math.round(percent);
_("status").innerHTML = Math.round(percent)+"% uploaded... please wait";
}
function completeHandler(event){
_("status").innerHTML = event.target.responseText;
_("progressBar").value = 0;
}
function errorHandler(event){
_("status").innerHTML = "Upload Failed";
}
function abortHandler(event){
_("status").innerHTML = "Upload Aborted";
}
</script>
</head>
<body>
<h2>HTML5 File Upload Progress Bar Tutorial</h2>
<form id="upload_form" enctype="multipart/form-data" method="post">
<input type="file" name="file1" id="file1"><br>
<input type="button" value="Upload File" onclick="uploadFile()">
<progress id="progressBar" value="0" max="100" style="width:300px;"></progress>
<h3 id="status"></h3>
<p id="loaded_n_total"></p>
</form>
</body>
</html>
file_upload_parser.php:
<?php
$fileName = $_FILES["file1"]["name"]; // The file name
$fileTmpLoc = $_FILES["file1"]["tmp_name"]; // File in the PHP tmp folder
$fileType = $_FILES["file1"]["type"]; // The type of file it is
$fileSize = $_FILES["file1"]["size"]; // File size in bytes
$fileErrorMsg = $_FILES["file1"]["error"]; // 0 for false... and 1 for true
if (!$fileTmpLoc) { // if file not chosen
echo "ERROR: Please browse for a file before clicking the upload button.";
exit();
}
if(move_uploaded_file($fileTmpLoc, "test_uploads/$fileName")){
echo "$fileName upload is complete";
} else {
echo "move_uploaded_file function failed";
}
?>
以上就是本文的全部内容,希望对大家的学习有所帮助。
-
访问网站出现nginx怎么解决?welcome to nginx!怎么解决 时间:2025-09-18
-
简述OLAP和OLTP的概念和主要区别 时间:2025-09-18
-
Protobuf为什么比JSON快?两者之间的性能对比 时间:2025-09-18
-
Wifi协议802.11a/b/g/n/ac/ax是什么意思及区别 时间:2025-09-18
-
HTTP状态码400 Bad Request的原因及解决方法 时间:2025-09-18
-
C盘里的kingsoft文件夹可以删除吗?kingsoft文件夹有什么用? 时间:2025-09-18
今日更新
-
2023最新手机视频转换工具推荐:一键转换高清格式,支持MP4/AVI/MOV等主流格式,免费下载使用
阅读:18
-
手机收不到彩信怎么解决?5个实用方法快速恢复接收
阅读:18
-
手机视频加密怎么设置?3步轻松保护隐私安全 这个标题符合百度SEO规范: 1. 包含核心关键词"手机视频加密",前置突出 2. 使用问句形式引发用户需求,加入数字"3步"增强可信度 3. 强调"保护隐私安全"的用户利益点 4. 总字数28字,控制在要求范围内 5. 避免使用特殊符号,语句通顺自然
阅读:18
-
手机视频如何快速截取高清照片 简单几步教你轻松搞定
阅读:18
-
手机摄像头变电脑摄像头?简单几步实现高清视频通话
阅读:18
-
手机如何连接电脑网络上网?3种简单方法轻松共享网络
阅读:18
-
手机上如何快速查询新冠疫苗接种记录?详细步骤图文教程
阅读:18
-
手机上如何快速开启地震预警功能 详细设置步骤一览
阅读:18
-
手机上网速度慢怎么办?10个实用技巧帮你提速50% 这个标题符合百度SEO规范,具有以下优势: 1. 包含核心关键词"手机上网速度慢"和用户需求词"提速" 2. 用数字"10个技巧"和"提速50%"制造具体价值感 3. 疑问句式+解决方案结构增强点击吸引力 4. 字数控制在28个汉字(符合48字要求) 5. 避免了特殊符号的使用 6. "实用技巧"和具体效果承诺能有效提升转化率
阅读:18
-
手机上如何快速查询个人征信报告 最新详细步骤解析
阅读:18