easyexcel下载excel文件名为空的问题

该博客记录了一个Java后端使用EasyExcel库生成并下载Excel文件的过程。通过`@RestController`注解的控制器方法,设置响应头并利用`EasyExcel`的API,将数据写入到HTTP响应的输出流中,实现了动态生成`学生表.xlsx`文件并提供下载的功能。`getStudentList()`方法用于模拟生成学生数据列表,整个过程对于处理批量数据导出非常实用。
摘要由CSDN通过智能技术生成
@RestController
public class StudentController {

    @RequestMapping("/download")
    public JsonResult download(HttpServletResponse response) throws IOException {
        //文件名需要这样写,不能在setHeader直接写中文名,否则下载的文件名字为空,只有后缀
        String fileName = new String("学生表.xlsx".getBytes(), StandardCharsets.ISO_8859_1);
        response.setContentType("application/vnd.ms-excel");
        response.setCharacterEncoding("utf8");
        response.setHeader("Content-disposition", "attachment;filename=" + fileName );
        EasyExcel.write(response.getOutputStream(), Student.class)
                .sheet("sheet")
                .doWrite(getStudentList());
        return new JsonResult().setCode(1).setMessage("下载成功!").setData(null);
    }

    private List getStudentList() {
        ArrayList<Student> students = new ArrayList<>();
        for (int i = 0; i < 1000; i++) {
            Student student = new Student(i, "名字" + i, i, new Date());
            students.add(student);
        }
        return students;
    }
}

困扰我了一会,特此记录,以备之需。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值