Spring Boot 导出 CSV 文件
Spring Boot CSV About 1,796 wordsCSV
comma-separated values
后端代码
生成 CSV
bom是为了解决中文乱码问题。
public String generateContent(List<Trade> trades) {
    String header = String.join(",", "订单号", "手机号", "订单状态", "金额", "创建时间");
    String csv = trades.stream().map(trade -> {
        return String.join(",", trade.getTradeId(), trade.getPhoneNumber(), trade.getStatus(), trade.getPayAmount(), trade.getCreateTs());
    }).collect(Collectors.joining(System.lineSeparator()));
    String bom = new String(new byte[]{(byte) 0xEF, (byte) 0xBB, (byte) 0xBF});
    return bom.concat(header).concat(System.lineSeparator()).concat(csv);
}
输出流
使用OutputStreamWriter包装,否则中文会乱码。
@GetMapping("/api/export")
public HttpServletResponse export(HttpServletResponse response) throws IOException {
    String csv = generateContent(...);
    try (OutputStreamWriter writer = new OutputStreamWriter(response.getOutputStream(), StandardCharsets.UTF_8)) {
        response.setContentType(MediaType.APPLICATION_OCTET_STREAM_VALUE);
        response.setHeader("Content-Disposition", "attachment;filename=file.csv");
        writer.write(csv);
        writer.flush();
    }
    return response;
}
前端代码
a 标签
对于没有Authorization等自定义Header的下载导出,可以使用<a href=""></a>标签。
axios
function exportCsv() {
  http.get("/api/export", {
    params: {
    },
    responseType: 'blob'
  }).then((response) => {
    const blob = new Blob([response])
    const downloadElement = document.createElement('a');
    const href = window.URL.createObjectURL(blob); //创建下载的链接
    downloadElement.href = href;
    downloadElement.download = `订单明细_${Date.now()}.csv`; //下载后文件名
    document.body.appendChild(downloadElement);
    downloadElement.click(); //点击下载
    document.body.removeChild(downloadElement); //下载完成移除元素
    window.URL.revokeObjectURL(href); //释放掉blob对象
  }).finally(() => {
  })
}
                Views: 1,849 · Posted: 2024-05-29
            
            ————        END        ————
Give me a Star, Thanks:)
https://github.com/fendoudebb/LiteNote扫描下方二维码关注公众号和小程序↓↓↓
 
        Loading...