全网整合营销服务商

电脑端+手机端+微信端=数据同步管理

免费咨询热线:400-708-3566

java web开发中大量数据导出Excel超时(504)问题解决

import java.io.IOException;
import java.io.OutputStream;
import java.lang.reflect.Field;
import java.text.SimpleDateFormat;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import javax.servlet.http.HttpServletResponse;
import org.apache.commons.lang3.StringUtils;
import org.joda.time.DateTime;
import com.travelzen.framework.net.http.TZHttpClient;
import com.travelzen.tops.front.ota.member.item.CustomerItem;
public class CSV {
  /**
   * 目标输出流
   */
  private OutputStream stream;
  /**
   * 表头
   */
  private Map<String,String> fields;

  /**
   * 数据源model所有字段map
   */
  private static Map<String, Field> fieldMap = new HashMap<>();
  public CSV(HttpServletResponse response,Map<String,String> fields,String fileName,Class<?> clz) throws IOException{
    if(response == null || fields == null || fileName == null || clz == null)
      throw new IllegalArgumentException();
    getFieldMap(clz,fieldMap);
    this.stream = response.getOutputStream();
    this.fields = fields;
    response.setContentType("application/octet-stream;charset=GBK");
    response.setHeader("Content-Disposition", "attachment;fileName="+ fileName);
    //写表头,生成指定名字的文件,返回客户端
    StringBuilder hb = new StringBuilder();
    for(Entry<String, String> e : fields.entrySet())
      hb.append(e.getValue()+",");
    stream.write(hb.substring(0, hb.length() - 1).getBytes("GBK"));
    stream.flush();
  }
  /**
   * 往表格中插入记录
   */
  public void write(List<Object> data) throws IllegalArgumentException, IllegalAccessException, IOException{
    for(Object o : data){
      StringBuilder sb = new StringBuilder();
      sb.append("\n");
      for(String field : fields.keySet()){
        Field f = fieldMap.get(field);
        f.setAccessible(true);
        Object value = f.get(o);
        if(value == null || StringUtils.isBlank(value.toString())){
          sb.append(" ,");
        } else if (f.getType() == Date.class) {
          sb.append(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(value) + ",");
        } else if (f.getType() == DateTime.class) {
          sb.append(((DateTime)value).toString("yyyy-MM-dd HH:mm:ss") + ",");
        } else {
          String tmp = value.toString();
          if(tmp.contains(","))
            tmp = tmp.replace(",", "\",\"");
          sb.append(value.toString() + ",");
        }
      }
      stream.write(sb.substring(0, sb.length() - 1).getBytes("GBK"));
      stream.flush();
    }
  }
  public void close() throws IOException{
    stream.close();
  }
  private static <T extends Object> void getFieldMap(Class<T> clz, Map<String, Field> result) {
    for (Field field : clz.getDeclaredFields()) {
      result.put(field.getName(), field);
    }
    if (clz.getSuperclass() != null) {
      getFieldMap(clz.getSuperclass(), result);
    }
  }
}

web开发中常见的准备Excel数据需要从数据库查询数据,或者跨系统调用接口查询数据,耗费大量时间,因此未及时向浏览器返回数据,导致504超时。

本工具使用ServletOutputStream分段的往浏览器flush数据。调用方式:先new CSV(),传入指定参数,不断的调用wirte()方法往浏览器写入数据,最后调用close方法关闭流。

本工具导出的文件格式为.csv文件,windows office工具默认编码为ASCI,wps会匹配各种编码,libreOffice calc可以指定编码,故此设置编码为GBK,兼容三种Excel软件,也可根据自身需求设置编码。

本工具只处理了CSV中”,”的转码,对于双引号并未处理。

希望本文能够对遇到此问题的朋友能有所帮助


# java大量数据导出Excel超时问题  # java导出excel超时  # java大量导出excel  # 基于java web获取网页访问次数代码实例  # Javaweb实现在线人数统计代码实例  # Javaweb监听器实例之统计在线人数  # 详解javaweb中jstl如何循环List中的Map数据  # Javaweb使用cors完成跨域ajax数据交互  # javaweb中mysql数据库连接步骤方法及其实例  # Java web数据可视化实现原理解析  # 也可  # 三种  # 格式为  # 客户端  # 数据库查询  # 双引号  # travelzen  # public  # framework  # CSV  # lt  # stream  # private  # CustomerItem  # front  # tops  # TZHttpClient  # ota  # item  # member 


相关文章: 阿里云高弹*务器配置方案|支持分布式架构与多节点部署  建站之星体验版:智能建站系统+响应式设计,多端适配快速建站  已有域名如何快速搭建专属网站?  定制建站模板如何实现SEO优化与智能系统配置?18字教程  制作证书网站有哪些,全国城建培训中心证书查询官网?  香港服务器网站卡顿?如何解决网络延迟与负载问题?  建站主机无法访问?如何排查域名与服务器问题  建站之星如何修改网站生成路径?  如何在建站之星绑定自定义域名?  成都网站制作公司哪家好,四川省职工服务网是做什么用?  外贸公司网站制作哪家好,maersk船公司官网?  如何在沈阳梯子盘古建站优化SEO排名与功能模块?  招贴海报怎么做,什么是海报招贴?  设计网站制作公司有哪些,制作网页教程?  建站之星Pro快速搭建教程:模板选择与功能配置指南  如何零基础在云服务器搭建WordPress站点?  c# 在ASP.NET Core中管理和取消后台任务  平台云上自助建站如何快速打造专业网站?  建站10G流量真的够用吗?如何应对访问高峰?  如何在阿里云ECS服务器部署织梦CMS网站?  Thinkphp 中 distinct 的用法解析  网站制作知乎推荐,想做自己的网站用什么工具比较好?  详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)  建站之星备案是否影响网站上线时间?  建站之星如何通过成品分离优化网站效率?  C++时间戳转换成日期时间的步骤和示例代码  如何在腾讯云服务器快速搭建个人网站?  建站之星安装后界面空白如何解决?  建站之星logo尺寸如何设置最合适?  制作网站公司那家好,网络公司是做什么的?  开封网站制作公司,网络用语开封是什么意思?  如何在云指建站中生成FTP站点?  黑客入侵网站服务器的常见手法有哪些?  如何高效完成独享虚拟主机建站?  免费的流程图制作网站有哪些,2025年教师初级职称申报网上流程?  ,购物网站怎么盈利呢?  如何选择美橙互联多站合一建站方案?  如何高效完成自助建站业务培训?  建站之星×万网:智能建站系统+自助建站平台一键生成  Python多线程使用规范_线程安全解析【教程】  如何用腾讯建站主机快速创建免费网站?  建站之星客服服务时间及联系方式如何?  如何打造高效商业网站?建站目的决定转化率  Android自定义listview布局实现上拉加载下拉刷新功能  Android自定义控件实现温度旋转按钮效果  GML (Geography Markup Language)是什么,它如何用XML来表示地理空间信息?  C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换  高端企业智能建站程序:SEO优化与响应式模板定制开发  如何在万网ECS上快速搭建专属网站?  合肥制作网站的公司有哪些,合肥聚美网络科技有限公司介绍? 

您的项目需求

*请认真填写需求信息,我们会在24小时内与您取得联系。