drogon/examples/simple_example/FileUpload.csp

87 lines
2.9 KiB
Plaintext
Raw Normal View History

2018-09-07 01:53:37 +00:00
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
2019-01-27 07:59:56 +00:00
<title>File upload</title>
2018-09-07 01:53:37 +00:00
<script type="text/javascript">
var xhr;
2019-01-27 07:59:56 +00:00
//File uploading method
2018-09-07 01:53:37 +00:00
function UpladFile() {
2019-01-27 07:59:56 +00:00
var fileObj = document.getElementById("file").files[0]; // js get file object
var url = "http://localhost:8848" + "/api/attachment/upload";
2018-09-07 01:53:37 +00:00
2019-01-27 07:59:56 +00:00
var form = new FormData(); // FormData object
form.append("file", fileObj); // File object
2018-09-07 01:53:37 +00:00
2019-01-27 07:59:56 +00:00
xhr = new XMLHttpRequest(); // XMLHttpRequest object
xhr.open("post", url, true); //post
xhr.onload = uploadComplete;
xhr.onerror = uploadFailed;
2018-09-07 01:53:37 +00:00
2019-01-27 07:59:56 +00:00
xhr.upload.onprogress = progressFunction;
xhr.upload.onloadstart = function(){
ot = new Date().getTime();
oloaded = 0;
2018-09-07 01:53:37 +00:00
};
2019-01-27 07:59:56 +00:00
xhr.send(form);
2018-09-07 01:53:37 +00:00
}
function uploadComplete(evt) {
var data = JSON.parse(evt.target.responseText);
2019-01-27 07:59:56 +00:00
if(data.result == "ok") {
alert("Uploaded successfully!");
2018-09-07 01:53:37 +00:00
}else{
2019-01-27 07:59:56 +00:00
alert("Upload failed!");
2018-09-07 01:53:37 +00:00
}
}
2019-01-27 07:59:56 +00:00
2018-09-07 01:53:37 +00:00
function uploadFailed(evt) {
2019-01-27 07:59:56 +00:00
alert("Upload failed!");
2018-09-07 01:53:37 +00:00
}
2019-01-27 07:59:56 +00:00
2018-09-07 01:53:37 +00:00
function cancleUploadFile(){
xhr.abort();
}
function progressFunction(evt) {
var progressBar = document.getElementById("progressBar");
var percentageDiv = document.getElementById("percentage");
if (evt.lengthComputable) {//
progressBar.max = evt.total;
progressBar.value = evt.loaded;
percentageDiv.innerHTML = Math.round(evt.loaded / evt.total * 100) + "%";
}
var time = document.getElementById("time");
2019-01-27 07:59:56 +00:00
var nt = new Date().getTime();
var pertime = (nt-ot)/1000;
ot = new Date().getTime();
var perload = evt.loaded - oloaded;
oloaded = evt.loaded;
var speed = perload/pertime;
2018-09-07 01:53:37 +00:00
var bspeed = speed;
2019-01-27 07:59:56 +00:00
var units = 'b/s';
2018-09-07 01:53:37 +00:00
if(speed/1024>1){
speed = speed/1024;
units = 'k/s';
}
if(speed/1024>1){
speed = speed/1024;
units = 'M/s';
}
speed = speed.toFixed(1);
var resttime = ((evt.total-evt.loaded)/bspeed).toFixed(1);
2019-01-27 07:59:56 +00:00
time.innerHTML = ',Speed: '+speed+units+', the remaining time: '+resttime+'s';
if(bspeed==0) time.innerHTML = 'Upload cancelled';
2018-09-07 01:53:37 +00:00
}
</script>
</head>
<body>
<progress id="progressBar" value="0" max="100" style="width: 300px;"></progress>
<span id="percentage"></span><span id="time"></span>
<br /><br />
<input type="file" id="file" name="myfile" />
2019-01-27 07:59:56 +00:00
<input type="button" onclick="UpladFile()" value="Upload" />
<input type="button" onclick="cancleUploadFile()" value="Cancel" />
2018-09-07 01:53:37 +00:00
</body>
</html>