java和excel的结合_java 导出excel(结合spring)

上代码

@RequestMapping(value = "/test", method = RequestMethod.GET)

public Result test(HttpServletRequest request, HttpServletResponse response){

try (OutputStream outputStream = response.getOutputStream()){

response.setHeader("Content-Disposition","attachment; filename="+ URLEncoder.encode("哒哒", "UTF-8") +".xls");

HSSFWorkbook wb = ExcelUtils.export(Arrays.asList("zm"));

wb.write(outputStream);

outputStream.flush();

}catch (IOException e){

LOGGER.error("exportOrderBill error. ", e);

return Result.error("导出失败." + e.getMessage());

}catch (Exception e){

LOGGER.error("exportOrderBill error. ", e);

return Result.error("导出失败." + e.getMessage());

}

return Result.error("导出失败.");

}

public static HSSFWorkbook export(Object data){

HSSFWorkbook hwb = new HSSFWorkbook();

//新增sheet

HSSFSheet sheet = hwb.createSheet();

int rowIndex = 0;

Row headerRow = sheet.createRow(rowIndex++);

String [] headers = {"姓名"};

//设置表头

for (int hIndex = 0; hIndex < headers.length ; hIndex++){

headerRow.createCell(hIndex).setCellValue(headers[hIndex]);

}

//设置内容

for (String str: list) {

//新增行

HSSFRow row = sheet.createRow(rowIndex++);

int cellIndex = 0;

//新增单元格

row.createCell(cellIndex++).setCellValue(str);

}

return hwb;

}

遇到的问题

文件名乱码

尝试如下设置,没有用

response.setCharacterEncoding("utf-8");

response.setContentType("application/octet-stream;utf-8");

response.setHeader("Content-Disposition","attachment; filename="哒哒.xls");

效果如下:

945605547b22

没改过来啊。。。

再试:

response.setHeader("Content-Disposition","attachment; filename="+ URLEncoder.encode("哒哒", "UTF-8") +".xls");

945605547b22

好了,搞定。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值