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); //年龄

sh

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java可以使用异步任务(AsyncTask)来实现异步导出Excel功能。AsyncTask是Android提供的一个轻量级的异步任务类,可以帮助我们方便地在后台执行一些耗时的操作,而不会阻塞主线程。 以下是异步导出Excel的大致步骤: 1. 在主线程中创建一个AsyncTask对象,并传入导出Excel所需的参数。 2. 在AsyncTask的doInBackground()方法中执行导出Excel的操作,并返回导出的结果。 3. 在AsyncTask的onPostExecute()方法中处理导出结果,并在UI线程中更新UI界面。 具体实现方法可以参考以下代码示例: ```java public class ExportExcelTask extends AsyncTask<String, Void, Boolean> { private Context mContext; private ProgressDialog mProgressDialog; public ExportExcelTask(Context context) { mContext = context; } @Override protected void onPreExecute() { super.onPreExecute(); mProgressDialog = new ProgressDialog(mContext); mProgressDialog.setMessage("正在导出,请稍候..."); mProgressDialog.show(); } @Override protected Boolean doInBackground(String... params) { // 导出Excel的操作,返回导出结果 boolean success = ExcelUtil.exportExcel(params[0], params[1], params[2]); return success; } @Override protected void onPostExecute(Boolean success) { super.onPostExecute(success); mProgressDialog.dismiss(); if (success) { Toast.makeText(mContext, "导出成功!", Toast.LENGTH_SHORT).show(); } else { Toast.makeText(mContext, "导出失败!", Toast.LENGTH_SHORT).show(); } } } ``` 在使用时,可以通过以下代码启动异步任务: ```java ExportExcelTask task = new ExportExcelTask(this); task.execute(filepath, sheetname, filename); ``` 其中,filepath为Excel文件存储路径,sheetname为工作表名称,filename为导出文件名。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值