java怎么实现异步导出_java实现异步导出数据

问题概述:

使用java作为后台语言,用poi导出数据时无法异步导出,当数据量稍微大点,就会出现页面傻瓜式等待 (点击导出后,页面无任何反应和提示,还以为此功能无效。然则几秒后浏览器才响应。)这样体验非常 不好。

解决办法:

很简单,将下载数据分离为一个单独方法。在触发导出后,先获取并封装数据(数据量大的话这个过程正好给页面做一个等待框,提示正在下载数据),完成后给前台返回一个状态,当前台收到返回正确返回状态后再关闭等待框并调用下载方法。

demo:

1、获取并封装数据

@RequestMapping("exportExcel") //用户数据导出

public void exportExcel(HttpServletRequest request, HttpServletResponse response) {

Map map = new HashMap();

try{

EquipmentAccident search=(EquipmentAccident)

request.getSession().getAttribute("equipmentAccident1"); //获取保存在session中的查询条件

if(search !=null ){

if(Str.isNotNull(search.getName())){ //名称

map.put("name", search.getName());

}

if(Str.isNotNull(search.getRemark())){ //备注

map.put("remark", search.getRemark());

}

}

List list=userService.selectExcel(map); //查询数据

XSSFWorkbook wb = new XSSFWorkbook(); // 声明一个工作薄

XSSFSheet sheet = wb.createSheet("用户信息"); // 生成一个表格

Integer columnIndex = 0;

sheet.setColumnWidth(columnIndex++, 3 * 512); // 设置表格第一列宽度为3个字节

sheet.setColumnWidth(columnIndex++, 10 * 512); //名称

sheet.setColumnWidth(columnIndex++, 10 * 512); //年龄

sheet.setColumnWidt

  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值