当前位置: 首页 > news >正文

使用easyexcel导出,发生了Exception: could not find acceptable repesentation

报错信息:

在这里插入图片描述

原因以及解决方案:

原因是我的代码使用Resp响应返回实体,其实使用EasyExcel导出已经设置了响应编码,导致重复了。
当你通过 HttpServletResponse 的输出流写入文件时,你已经直接控制了响应体。如果此时还尝试返回一个包含响应体的 ResponseEntity,那么Spring MVC可能会尝试再次写入响应体,这会导致冲突或覆盖你之前写入的内容。

    @GetMapping("/export")public Resp easyexcelExport(HttpServletResponse response){try {// ...省略其他代码// 定义定义文件名String filename = URLEncoder.encode("用户列表", "UTF-8");response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");response.setHeader("Content-Disposition","attachment;filename=" + filename + ".xlsx");EasyExcel.write(response.getOutputStream(), TbUser.class).sheet("sheet1").doWrite(tbUserList);} catch (IOException e) {throw new RuntimeException(e);}return Resp.success();}

解决方案:

  • 如果你的控制器方法只负责导出文件,并且文件已经通过HttpServletResponse发送,那么方法应该直接返回void或null,而不是ResponseEntity。
  • 确保你没有在发送文件后尝试设置任何响应体或状态码(这些应该通过HttpServletResponse来设置)。

返回类型使用void就正常了。
在这里插入图片描述

结束!!!!!
hy:69


				后来我才想明白,与其担心未来,不如现在好好努力。这条路上,只有奋斗才能给你安全感。
http://www.lryc.cn/news/418951.html

相关文章:

  • android display 笔记(五)HWC(Hardware Composer)
  • 【模电笔记】——集成运算放大电路
  • Android Studio Gradle多渠道打包
  • 什么是DNS缓存?DNS缓存有哪些作用和危害?
  • web基础与http协议与配置
  • 机械学习—零基础学习日志(python编程2)
  • element-plus的表单输入框有清除按钮的,文字输入前后宽度不一致怎么解决
  • 解决Docker拉取镜像时 i/o timeout错误
  • 面壁的智能开源 MiniCPM-V 2.6 边缘人工智能多模态功能与 GPT-4V 不相上下
  • dhcp+checkkickstar的实验理解
  • Android网络安全:如何防止中间人攻击
  • NOI Linux 2.0 的安装说明以及使用指南
  • 07、MySQL-多表查询
  • 20240809 每日AI必读资讯
  • 《投资的原理》阅读笔记一
  • 金九银十,全网最详细的软件测试面试题总结
  • ActiveMQ任意文件写入漏洞(CVE-2016-3088)复现
  • 网络协议四 物理层,数据链路层
  • Python知识点:如何使用Twisted进行异步网络编程
  • 循环神经网络
  • SQL进阶技巧:有序数据合并问题之如何按照指定的规则对数据进行合并?【详解collect_list函数有序性保证】
  • windows和office微软官方免费激活教程
  • 【C++ 面试 - 基础题】每日 3 题(七)
  • Java面试题精选:消息队列(一)
  • 宝塔面板启用 QUIC 与 Brotli 的完整教程
  • Linux 进程调度(二)之进程的上下文切换
  • Oracle事物临时表
  • 看图学sql之sql的执行顺序
  • 百日筑基第四十五天-从JAVA8走到JAVA9
  • 力扣第五十七题——插入区间