springboot上传文件显示上传进度[通俗易懂]

springboot上传文件显示上传进度[通俗易懂]springboot上传文件显示上传进度创建maven依赖 <dependency><groupId>commons-fileupload</groupId><artifactId>commons-fileupload</artifactId><version>1.2.2</version></dependency

大家好,又见面了,我是你们的朋友全栈君。

springboot上传文件显示上传进度

  1. 创建maven依赖
		<dependency>
            <groupId>commons-fileupload</groupId>
            <artifactId>commons-fileupload</artifactId>
            <version>1.2.2</version>
        </dependency>
  1. 新建实体类
@Data
@EqualsAndHashCode(callSuper = false)
@Accessors(chain = true)
public class ProgressEntity { 
   


    /** * 读取的文件的比特数 */
    private long bytesRead = 0L;

    /** * 文件的总大小 */
    private long contentLength = 0L;

    /** * 目前正在读取第几个文件 */
    private int items;

    /** * 开始上传时间,用于计算上传速率 */
    private long startTime = System.currentTimeMillis();

}
  1. 新建监听器
/** * * @author Administrator * * 要获得上传文件的实时详细信息,必须继承org.apache.commons.fileupload.ProgressListener类, * 获得信息的时候将进度条对象Progress放在该监听器的session对象中 */
@Component
public class FileUploadProgressListener implements ProgressListener { 
   

    private HttpSession session;

    public void setSession(HttpSession session){ 
   
        this.session=session;
        //保存上传状态
        ProgressEntity progressEntity = new ProgressEntity();
        session.setAttribute("progressEntity", progressEntity);
    }

    @Override
    public void update(long bytesRead, long contentLength, int items) { 
   
        ProgressEntity progressEntity = (ProgressEntity) session.getAttribute("progressEntity");
        //已读取数据长度
        progressEntity.setBytesRead(bytesRead);
        //文件总长度
        progressEntity.setContentLength(contentLength);
        //正在保存第几个文件
        progressEntity.setItems(items);
    }
}

  1. 新建文件解析器
/** * @author Administrator * * SpringMVC默认有一个文件解析器CommonsMultipartResolver用来解析上传的文件,我们需要重写该类, * 自己重写的监听器放到org.apache.commons.fileupload.FileUpload中,还需要将session放到自定义的监听器中 */

public class CustomMultipartResolver extends CommonsMultipartResolver { 
   

    /** * 注入第二步写的FileUploadProgressListener * 此处一定要检查是否注入成功了,不成功的话会报错 */
    @Autowired
    private FileUploadProgressListener progressListener;

    public void setProgressListener(FileUploadProgressListener progressListener) { 
   
        this.progressListener = progressListener;
    }

    @Override
    public MultipartParsingResult parseRequest(HttpServletRequest request) throws MultipartException { 
   
        String encoding = determineEncoding(request);
        FileUpload fileUpload = prepareFileUpload(encoding);
        progressListener.setSession(request.getSession());
        fileUpload.setProgressListener(progressListener);
        try { 
   
            List<FileItem> fileItems = ((ServletFileUpload) fileUpload).parseRequest(request);
            return parseFileItems(fileItems, encoding);
        } catch (FileUploadBase.SizeLimitExceededException ex) { 
   
            throw new MaxUploadSizeExceededException(fileUpload.getSizeMax(), ex);
        } catch (FileUploadException ex) { 
   
            throw new MultipartException("Could not parse multipart servlet request", ex);
        }
    }

}
  1. 指定自定义解析器
@Configuration
public class CorsConfig implements WebMvcConfigurer { 
   

    /** * 指定自定义解析器 * 将 multipartResolver 指向我们刚刚创建好的继承 CustomMultipartResolver 类的 自定义文件上传处理类 * * @return */
    @Bean(name = "multipartResolver")
    public MultipartResolver multipartResolver() { 
   
        return new CustomMultipartResolver();
    }
}
  1. 控制器调用方法
 /** * 获取上传进度 * * @return */
    @GetMapping(value = "/uploadStatus")
    @ApiOperation("获取上传进度")
    public Object uploadStatus() { 
   
        HttpServletRequest request = HttpContextUtils.getHttpServletRequest();
        HttpSession session = request.getSession();
        ProgressEntity percent = (ProgressEntity) session.getAttribute("progressEntity");
       // System.out.println("^^^^"+percent.toString());
      //当前时间
        long nowTime = System.currentTimeMillis();
        //已传输的时间
        long time = (nowTime - percent.getStartTime())/1000+1;
        //传输速度 ;单位:byte/秒
        double velocity =((double) percent.getBytesRead())/(double)time;
        //估计总时间
        double totalTime = percent.getContentLength()/velocity;
        //估计剩余时间
        double timeLeft = totalTime - time;
        //已经完成的百分比
        int percent1 = (int)(100 * (double) percent.getBytesRead() / (double) percent.getContentLength());
        //已经完成数单位:m
        double length = ((double) percent.getBytesRead())/1024/1024;
        //总长度 M
        double totalLength = (double) percent.getContentLength()/1024/1024;
        StringBuffer sb = new StringBuffer();
        //拼接上传信息传递到jsp中
        sb.append(percent+":"+length+":"+totalLength+":"+velocity+":"+time+":"+totalTime+":"+timeLeft+":"+percent.getItems());
        System.out.println("百分比====>"+percent1);
        System.out.println("已传输时间====>"+time+"------剩余时间--->"+timeLeft+"======已经完成===="+length);
        return null;
    }

原文链接:https://blog.csdn.net/FurtherSkyQ/article/details/98200965

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/136756.html原文链接:https://javaforall.net

(0)
上一篇 2022年6月3日 上午7:36
下一篇 2022年6月3日 上午7:46


相关推荐

  • plot中的 markersize

    plot中的 markersizemarkersize plot 0 1 2 3 4 0 2 5 6 9 c pentagram markersize 15 画图的命令是 marker 是图上画上点的地方表上符号 不如点 方框 圆框 十字 星号 等等后面的 size 就是其大小了 不知道值的话 可以画完图点编辑框上面的箭头 然后双击画的图 下面出现属性框 marker 项后面的数字下拉菜单就是 size 选择合适的

    2026年3月17日
    2
  • 数据结构——线索化二叉树和哈夫曼树[通俗易懂]

    数据结构——线索化二叉树和哈夫曼树[通俗易懂]线索化二叉树和哈夫曼树基础知识介绍与代码分析一、基础知识介绍二、代码分析:线索二叉树(采用中序遍历)#include “pch.h”#include <iostream>using namespace std;//定义线索二叉树typedef struct Tree{ int data, LTag, RTag; //定义数据域与标记域 Tre…

    2022年8月18日
    12
  • 基于ADS500MHZ带通滤波器「建议收藏」

    基于ADS500MHZ带通滤波器「建议收藏」《高频电子线路》专题实践报告题目:500Mhz带通滤波器设计500Mhz带通滤波器设计专题相关理论基础及对应ADS仿真要点2.1设计目的2.1.1了解巴特沃斯型滤波器、切比雪夫型滤波器、椭圆函数滤波器各自特性;2.1.2掌握运用ADS软件进行500MHZ带通滤波器优化设计;…

    2022年5月9日
    205
  • linux 误删文件恢复_centos删除的文件能恢复吗

    linux 误删文件恢复_centos删除的文件能恢复吗本文参考http://write.blog.csdn.net/postedit?ticket=ST-491405-OGjDDusZeyMgVQ7bHW7f-passport.csdn.net前言作为一个多用户、多任务的操作系统,Linux下的文件一旦被删除,是难以恢复的。尽管删除命令只是在文件节点中作删除标记,并不真正清除文件内容,但是其他用户和一些有写盘动作的进程会很快覆盖这些数据。不过……

    2022年8月21日
    9
  • DynamoDB常见问题

    DynamoDB常见问题什么是 DynamoDB 问 什么是 AmazonDynamo AmazonDynamo 是一项完全托管的 NoSQL 数据库服务 提供快速而可预测的性能 能够实现无缝扩展 使用 AmazonDynamo 客户可以将运行和扩展分布式数据库的管理工作负担交给 AWS 因而无需担心硬件预配 设置和配置 复制 软件更新或集群扩展等问题 问 AmazonDynamo 可以代我进行哪

    2026年3月19日
    2
  • 引用类型的一些方法

    引用类型的一些方法

    2022年3月12日
    48

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号