springboot后端返回图片,vue前端接收并显示的解决方案

news/2024/11/29 3:51:10/

后端图片数据返回

后端通过二进制流的形式,写入response中

controller层

    /*** 获取签到二维码*/@GetMapping("/sign-up-pict")public void signUpPict(Long id, Long semId, HttpServletResponse response) throws NoSuchAlgorithmException {signUpService.getImage(id, semId, response);}

service层

/*** 返回二维码** @param id    教师id* @param semId 课程id* @param response* @return*/@Overridepublic void getImage(Long id, Long semId, HttpServletResponse response) throws NoSuchAlgorithmException {// 保存生成的二维码图片BufferedImage image = new BufferedImage(width, height, BufferedImage.TYPE_INT_RGB);// 业务逻辑, 全部忽略删除了...// 设置返回数据类型response.setContentType("image/png");try {// 将图片数据写入out中OutputStream out = response.getOutputStream();// 将图片数据写入out中, 返回前端ImageIO.write(image, "png", out);out.close();}catch (IOException e) {throw new RRException(ErrorCode.IMAGE_GENERATE_FAILED);}}

前端axios接受数据

axios接受数据时,responseType 默认返回数据类型是 json,必须将其改为返回数据类型 blob。否则axois无法正确解析数据。
这里的http.request是对axios的封装,把他当作axios用就行

return http.request<R<any>>("get",signModuleUrlApi(`/signup/sign-up-pict?id=${id}&semId=${semId}`),// 一定要加, 否则axios会把二进制数据处理为json{responseType: "blob"});

vue界面渲染

<template><!-- 忽略其它部分代码, 下面这货显示图片--><el-image :src="url" lazy />
<\template><script>const url = ref();// 发送请求signApi.signUpPict(id, semId.value).then(res => {const blob = new Blob([res], { type: "image/png" });// 创建URL对象url.value = URL.createObjectURL(blob);},error => {console.log(error);ElMessage.error("系统错误, 无法生成二维码");});};
<\script>

注意事项

  1. 后端接口,最好不要有返回值,如果你设置了response.setContentType(“image/png”),很有可能在返回数据的时候出现序列化错误的bug
  2. 后端接口,最好对response的contentType设置一下,不然容易出现一些奇怪的bug
  3. 前端axios一定要设置responseType: “blob”,否则axios会把数据当成json处理

学习文章

https://zhuanlan.zhihu.com/p/474173086
https://www.jianshu.com/p/12fea9987c2d


http://www.ppmy.cn/news/1051595.html

相关文章

Linux---用户权限管理

权力下放 sudo工具&#xff0c;可以将root的权限下放到普通用户&#xff0c;它允许系统管理员分配给普通用户一些合理的“权力”&#xff0c;让他们执行一些只有超级用户或其他特许用户才能完成的任务&#xff08;主要体现为命令&#xff09;&#xff0c;比如&#xff1a;运行…

innovus加decap如何避免drc问题

我正在「拾陆楼」和朋友们讨论有趣的话题&#xff0c;你⼀起来吧&#xff1f; 拾陆楼知识星球入口 加decap常见的问题就是跟regular wire产生drc&#xff0c;调试如下命令能够避免这类drc。 setFillerMode -add_fillers_with_drc false -fitGap false -ecoMode true

Echarts面积图2.0(范围绘制)

代码&#xff1a; // 以下代码可以直接粘贴在echarts官网的示例上 // 范围值 let normalValue {type: 内部绘制,minValue: 200,maxValue: 750 } // 原本的绘图数据 let seriesData [820, 932, 901, 934, 1290, 1330, 1320] let minData Array.from({length: seriesData.len…

江南大学采购ZJ-3型精密D33测试仪四件套设备

江南大学采购ZJ-3型精密D33测试仪四件套设备 江南大学&#xff08;Jiangnan University&#xff09;&#xff0c;坐落于江苏省无锡市&#xff0c;是中华人民共和国教育部直属高校&#xff0c;由教育部、江苏省人民政府共建 &#xff0c;国家“双一流”建设高校&#xff0c; “…

Linux 多线程中执行fork的情况

一、普通多线程中执行fork的情况 1.多线程中没有执行fork的情况 代码如下&#xff1a; #include<stdio.h> #include<stdlib.h> #include<unistd.h> #include<pthread.h> #include<string.h> #include<semaphore.h>void*fun(void* arg) …

TLIN1021A-Q1 故障保护 LIN 收发器

​​​​​​目录 ​​1 特性 2 应用 3 说明 5描述(续) 6引脚配置和功能 7规范

Matlab论文插图绘制模板第108期—特征渲染的标签散点图

在之前的文章中&#xff0c;分享了Matlab标签散点图的绘制模板&#xff1a; 进一步&#xff0c;再来分享一下特征渲染的标签散点图的绘制模板&#xff0c;以便再添加一个维度的信息。 先来看一下成品效果&#xff1a; 特别提示&#xff1a;本期内容『数据代码』已上传资源群中…

LInux之例行工作

目录 场景 单一执行例行任务 --- at&#xff08;一次性&#xff09; 安装 命令详解 语法格式 参数及作用 时间格式 案例 at命令执行过程分析 循环执行的例行性任务--crontab&#xff08;周期性&#xff09; crontd服务安装 linux 任务调度的工分类 crontab工作过程…