JS之——纯js实现最简单的文件上传(后台使用MultipartFile)

转载请注明出处:https://blog.csdn.net/l1028386804/article/details/80938973

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>XMLHttpRequest上传文件</title>
    <script type="text/javascript">
        //图片上传
        var xhr;
        //上传文件方法
        function UpladFile() {
            var fileObj = document.getElementById("file").files[0]; // js 获取文件对象
            var url =  "http://localhost:8080" + "/api/attachment/upload"; // 接收上传文件的后台地址

            var form = new FormData(); // FormData 对象
            form.append("file", fileObj); // 文件对象

            xhr = new XMLHttpRequest();  // XMLHttpRequest 对象
            xhr.open("post", url, true); //post方式,url为服务器请求地址,true 该参数规定请求是否异步处理。
            xhr.onload = uploadComplete; //请求完成
            xhr.onerror =  uploadFailed; //请求失败

            xhr.upload.onprogress = progressFunction;//【上传进度调用方法实现】
            xhr.upload.onloadstart = function(){//上传开始执行方法
                ot = new Date().getTime();   //设置上传开始时间
                oloaded = 0;//设置上传开始时,以上传的文件大小为0
            };

            xhr.send(form); //开始上传,发送form数据
        }

        //上传成功响应
        function uploadComplete(evt) {
            //服务断接收完文件返回的结果

            var data = JSON.parse(evt.target.responseText);
            if(data.success) {
                alert("上传成功!");
            }else{
                alert("上传失败!");
            }

        }
        //上传失败
        function uploadFailed(evt) {
            alert("上传失败!");
        }
        //取消上传
        function cancleUploadFile(){
            xhr.abort();
        }


        //上传进度实现方法,上传过程中会频繁调用该方法
        function progressFunction(evt) {
            var progressBar = document.getElementById("progressBar");
            var percentageDiv = document.getElementById("percentage");
            // event.total是需要传输的总字节,event.loaded是已经传输的字节。如果event.lengthComputable不为真,则event.total等于0
            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");
            var nt = new Date().getTime();//获取当前时间
            var pertime = (nt-ot)/1000; //计算出上次调用该方法时到现在的时间差,单位为s
            ot = new Date().getTime(); //重新赋值时间,用于下次计算
            var perload = evt.loaded - oloaded; //计算该分段上传的文件大小,单位b
            oloaded = evt.loaded;//重新赋值已上传文件大小,用以下次计算
            //上传速度计算
            var speed = perload/pertime;//单位b/s
            var bspeed = speed;
            var units = 'b/s';//单位名称
            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);
            time.innerHTML = ',速度:'+speed+units+',剩余时间:'+resttime+'s';
            if(bspeed==0) time.innerHTML = '上传已取消';
        }
    </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" />
<input type="button" οnclick="UpladFile()" value="上传" />
<input type="button" οnclick="cancleUploadFile()" value="取消" />
</body>
</html>

Java使用MultipartFile实现文件上传和下载功能。MultipartFile是Spring框架提供的一个工具类,用于处理文件上传的相关操作。通过MultipartFile,我们可以轻松地实现文件上传、多文件上传以及文件下载功能。 在Java中,我们可以通过使用@RequestParam注解来接收前端传来的文件参数,将MultipartFile对象作为方法的参数。例如,可以使用以下代码来实现文件上传功能: ```java public String uploadFile(@RequestParam("file") MultipartFile file) { // 处理文件上传的逻辑 // ... return "上传成功"; } ``` 在上面的代码中,我们使用@RequestParam注解来指定前端传来的参数名为"file",并将其封装为MultipartFile对象。 对于多文件上传,可以将MultipartFile对象封装在一个List或数组中,从而处理多个文件的上传。例如: ```java public String uploadFiles(@RequestParam("files") List<MultipartFile> files) { // 处理多文件上传的逻辑 // ... return "上传成功"; } ``` 除了文件上传,我们还可以使用MultipartFile实现文件下载功能。通过MultipartFile对象,我们可以获取文件的字节流,并将其写入到输出流中,以实现文件下载。以下是一个简单的示例代码: ```java public void downloadFile(HttpServletResponse response) throws IOException { File file = new File("path/to/file"); // 文件路径 byte[] fileContent = Files.readAllBytes(file.toPath()); response.setContentType("application/octet-stream"); response.setHeader("Content-Disposition", "attachment; filename=" + file.getName()); OutputStream outputStream = response.getOutputStream(); outputStream.write(fileContent); outputStream.flush(); outputStream.close(); } ``` 在上述代码中,我们首先读取文件内容并将其写入到字节数组中。然后,我们设置响应头的Content-Type为"application/octet-stream",表示将以流的形式下载文件。同时,我们通过Content-Disposition设置文件名,将其作为附件下载。最后,将文件内容写入到响应的输出流中,实现文件下载。 通过使用MultipartFile,我们可以方便地实现Java中的文件上传和下载功能。无论是单文件上传、多文件上传还是文件下载,MultipartFile都能帮助我们处理文件操作的细节。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [Java利用MultipartFile实现上传多份文件的代码](https://download.csdn.net/download/weixin_38603704/12746436)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [【java开发】使用MultipartFile进行文件上传的例子](https://blog.csdn.net/weixin_34208283/article/details/91725990)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [SpringBoot结合MultipartFile实现文件上传与文件下载](https://blog.csdn.net/weixin_44176169/article/details/105320502)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

冰 河

可以吃鸡腿么?

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值