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

前端导出文件时,后端代码出错如何将错误信息返回给前端展示

功能说明:前端导出excel时,后端出现异常,比如sql异常,或者创建excel时出现的异常,希望将这些异常信息返回给前端查看。

框架:vue3 + axios + Springboot

实现难度分析:前端导出excel,axios 需要设置responseType=“blob”, axios的response监听器需要判断后端返回的是否时blob类型,并将整个response返回给axios接口的then(),然而后端我们代码如果正常的情况下,返回的blob,异常情况下,返回的异常信息字符串。

实现代码:
java层:再catch内对response重新定义,并且自定义一个状态码;

@PostMapping("/export")
public void exportFile(@RequestBody map, HttpServletResponse response) {try {// todo 导出excel流程代码,最后将workbook 写入到response内 ,如果方法体内调用的自定义函数有try...catch(Exception e)... 需要将异常手动抛到最外层 throw new Exception(e)} catch(Exception e) {// 这里接收所有的异常信息response.setStatus(260); // 定义一个状态码,用于前端的判断,只能是2开头的,其他开头的,到不了前端axios响应拦截器方法体内response.setContentType("text/plain"); //定义文本类型response.setCharacterEncoding("UTF-8");try (PrintWriter out = response.getWriter()){out.print(e.getMessage()); // 将异常信息写入到response内}e.printStackTrace();}
}

vue 端判断自定义状态码,并做异常信息输出

// 某个导出按钮触发的
const export = () =>{axios({  url: 'http://xxx/export',  responseType: 'blob',  }).then((response)=>{if(response.status === 260) {// 接收前端的异常信息,由于是blob类型,我们需要将blob转文本;blobToString (new Blob([response.data],{type: 'text/plain'}) , (text)=>{Message.error(text); // 异常信息文本})}else {// todo 将excel blob流下载到浏览器}});
}const blobToString = (blob, callback) => {  let reader = new FileReader();  reader.onload = function(event) {  let text = event.target.result;  callback(text);  };  reader.onerror = function(error) {  console.error('Error reading blob as text:', error);  };  reader.readAsText(blob);  
}  

axios 响应拦截器

axios.interceptors.response.use((response:AxiosResponse<HttpResponse>)=>{if(response.config.responseType==="arraybuffer" || response.config.responseType==="blob" || response.data instanceof Blob) {return response; // 文件流} else {//todu 对非文件流请求的统一处理return response.data;}
})
http://www.lryc.cn/news/397001.html

相关文章:

  • 解决Spring Boot应用中的内存优化问题
  • shark云原生-日志体系-filebeat高级配置(适用于生产)-更新中
  • 响应式设计的双璧:WebKit 支持 CSS Flexbox 和 Grid 布局深度解析
  • Linux软件包管理
  • 如何分辨AI生成的内容?AI生成内容检测工具对比实验
  • Clion中怎么切换不同的程序运行
  • 【C++初阶】C++入门(下)
  • 【3】迁移学习模型
  • 【工具分享】FOFA——网络空间测绘搜索引擎
  • [嵌入式 C 语言] 按位与、或、取反、异或
  • Android --- 运行时Fragment如何获取Activity中的数据,又如何将数据传递到Activity中呢?
  • Java后端开发(十三)-- Java8 stream的 orElse(null) 和 orElseGet(null)
  • L2 LangGraph_Components
  • 09.C2W4.Word Embeddings with Neural Networks
  • 硅谷甄选二(登录)
  • scipy库中,不同应用滤波函数的区别,以及FIR滤波器和IIR滤波器的区别
  • 简谈设计模式之建造者模式
  • 力扣 hot100 -- 动态规划(下)
  • 【计算机毕业设计】018基于weixin小程序实习记录
  • 力扣之有序链表去重
  • Apache配置与应用(优化apache)
  • 怎么将3张照片合并成一张?这几种拼接方法很实用!
  • YOLOv10改进 | 图像去雾 | MB-TaylorFormer改善YOLOv10高分辨率和图像去雾检测(ICCV,全网独家首发)
  • spring boot读取yml配置注意点记录
  • 电子电气架构 --- 关于DoIP的一些闲思 下
  • Java getSuperclass和getGenericSuperclass
  • ARM功耗管理标准接口之ACPI
  • 2024年网络监控软件排名|10大网络监控软件是哪些
  • 通过Arcgis从逐月平均气温数据中提取并计算年平均气温
  • 每日一题~abc356(对于一串连续数字 找规律,开数值桶算贡献)