简述Java异步上传文件的三种方式
本文为大家分享了三种Java异步上传文件方式,供大家参考,具体内容如下
第一种使用浏览器插件上传,需要一定的底层编码功底,在这里我就不讲了,以免误人子弟,提出这点大家可以自行百度。 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>隐藏的iframe上传文件</title> <script type="text/javascript" src="jquery路径..."></script> </head> <body> <iframe name="frm" style="display:none"></iframe> <form action="/upload2" enctype="multipart/form-data" method="post" target="frm" onsubmit="loading(true);"> <p id="upfile">附件: <input type="file" name="myfile" style="display: inline"> </p> <p id="upbtn"> <input style="padding-left:50px;padding-right: 50px;" type="submit" value="异步上传"> <span id="uptxt" style="display: none">正在上传...</span> </p> </form> <div id="flist" style="border:1px dotted darkgray;"></div> <script> // 上传完成后的回调 function uploadFinished(fileName) { addToFlist(fileName); loading(false); } function addToFlist(fname) { var temp = ["<p id='" + fname + "'>",fname,"<button onclick='delFile("" + fname + "");'>删除</button>","</p>" ]; $("#flist").append(temp.join("")); } function loading(showloading) { if (showloading) { $("#uptxt").show(); } else { $("#uptxt").hide; } } </script> </body> </html> 这种技术有两个关键的地方: router.post('/upload2',multipartMiddleware,function(req,res) { var fpath = req.files.myfile.path; var fname = fpath.substr(fpath.lastIndexOf('') + 1); setTimeout(function { var ret = ["<script>","window.parent.uploadFinished('" + fname + "');","</script>"]; res.send(ret.join("")); },3000); }); 执行后可以打开开发人员选项,你会发现隐藏iframe中返回了服务器的一些数据。 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>xhr level2 异步上传</title> <script type="text/javascript" src="jquery路径..."></script> </head> <body> <div> <p id="upfile">附件: <input type="file" id="myfile" style="display: inline"></p> <p id="upbtn"> <input style="padding-left:50px;padding-right: 50px;" type="button" value="异步上传" onclick="upload;"> <span id="uptxt" style="display: none">正在上传...</span> <span id="upprog"></span> <button id="stopbtn" style="display:none;">停止上传</button> </p> </div> <div id="flist" style="border:1px dotted darkgray;"></div> <script> function upload { // 1.准备FormData var fd = new FormData; fd.append("myfile",$("#myfile")[0].files[0]); // 创建xhr对象 var xhr = new XMLHttpRequest; // 监听状态,实时响应 // xhr 和 xhr.upload 都有progress事件,xhr.progress是下载进度,xhr.upload.progress是上传进度 xhr.upload.onprogress = function(event) { if (event.lengthComputable) { var percent = Math.round(event.loaded * 100 / event.total); console.log('%d%',percent); $("#upprog").text(percent); } }; // 传输开始事件 xhr.onloadstart = function(event) { console.log('load start'); $("#upprog").text('开始上传'); $("#stopbtn").one('click',function { xhr.abort; $(this).hide();}); loading(true); }; // ajax过程成功完成事件 xhr.onload = function(event) { console.log('load success'); $("#upprog").text('上传成功'); console.log(xhr.responseText); var ret = JSON.parse(xhr.responseText); addToFlist(ret.fname); }; // ajax过程发生错误事件 xhr.onerror = function(event) { console.log('error'); $("#upprog").text('发生错误'); }; // ajax被取消 xhr.onabort = function(event) { console.log('abort'); $("#upprog").text('操作被取消'); }; // loadend传输结束,不管成功失败都会被触发 xhr.onloadend = function (event) { console.log('load end'); loading(false); }; // 发起ajax请求传送数据 xhr.open('POST','/upload3',true); xhr.send(fd); } function addToFlist(fname) { var temp = ["<p id='" + fname + "'>","</p>" ]; $("#flist").append(temp.join("")); } function delFile(fname) { console.log('to delete file: ' + fname); // TODO: 请实现 } function loading(showloading) { if (showloading) { $("#uptxt").show(); $("#stopbtn").show(); } else { $("#uptxt").hide(); $("#stopbtn").hide(); } } </script> </body> </html> 代码有点多,但是通俗易懂。使用过AJAX的人都知道,XHR对象提供了一个onreadystatechange的回调方法来监听整个请求/响应过程。在XMLHttpRequest2级规范中又多了几个进度事件。有以下6个事件: 1.loadstart: 在接收到响应数据的第一个字节时触发。 这次我们可以解读代码:当传输事件开始后,我们便在停止传送按钮上添加点击事件,内置了abort方法可以停止传送。若不点则会正常上传直到传送完毕为止。其后台代码类似第二种方法。 以上就是本文的全部内容,希望对大家的学习有所帮助。 (编辑:4S站长网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |