eggjs 怎么实现返回 base64 图片的接口给前端回显头像?

简介: eggjs 怎么实现返回 base64 图片的接口给前端回显头像?

接着上一篇,我们这篇实现接口返回 base64 给到前端去回显头像 ,昨天我们实现了把图片的唯一性数据存到了本地数据库,下面实现一下读取图片的逻辑:


  1.    前端通过唯一性数据发起请求
  2.    后端通过前端传过来的唯一性数据找到服务器文件路径
  3.    读取文件返回 base64 数据
  4.    前端接收到服务端数据拿去用 img 标签渲染



4fab16b2d9794c37882852ae07f98131.png


1、新建路由

// 获取头像
router.get('/api/upload/getAvatar', verify_token, controller.upload.getAvatar);


2、编写生成 base64 逻辑

我们在 upload.js 里面添加下面方法

async getAvatar () {
  const { ctx, config } = this;
  try {
    // 0、获取图片名称
    let picname = ctx.request.body.picname;
    console.log('0、获取图片名称', picname);
    // 1、判断
    if(!picname) {
      ctx.body = {
        status: 400,
        desc: 'picname 参数必传',
        data: null
      }
      return;
    }
    // 拼接图片保存的路径
    let dir = path.join(config.uploadAvatarDir, [picname.split("_")[0], picname].join("/"));
    console.log('1、拼接图片保存的路径', dir);
    // 前缀
    let prefix = "data:" + path.extname(picname).slice(1) + ";base64,"
    // 读取文件 转成 base64
    let base64 = fs.readFileSync(dir, 'base64');
    console.log(prefix);
    ctx.body = {
      status: 200,
      desc: '获取成功',
      data: prefix + base64
    };
  } catch(error) {
    ctx.body = {
      status: 500,
      desc: '获取失败',
      data: null
    };
  }
}


3、测试接口

我们假如已经接收到前端传的参数,通过 picname 接收参数,点击运行,结果如下

d356506b140a47ac9c1360e27bbad622.png

{
  "status": 200,
  "desc": "获取成功",
  "data": "data:png;base64,iVBORw0KGgoAAAANSUhEUgAAB24AAAObCAYAAACb16FPAAAgAElEQV...."
}


4、前端页面回显


写法如下:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>头像回显</title>
</head>
<body>
  <img src="data:png;base64,iVBORw0KGgoAAAANSUhEUgAAB24AAAObCAYAAACb16FPAAAgAElEQV...." alt="">
</body>
</html>

效果如下:

afc538451f0c4950956c59ca6dde7654.png



目录
相关文章
|
1月前
|
存储 前端开发 JavaScript
🚀前端轻松实现网页内容转换:一键复制、保存图片及生成 Markdown
在现代前端开发中,提升用户的交互体验至关重要。本文将详细介绍如何使用 HTML2Canvas 和 Turndown 两个强大的 JavaScript 库,实现将网页选中文本转化为图片并保存或复制到剪贴板,或将内容转换为 Markdown 格式。文章包含核心代码实现、技术细节和功能拓展方向,为开发者提供了一个轻量级的解决方案,提升用户体验。
138 68
|
27天前
|
存储 前端开发 JavaScript
前端的全栈之路Meteor篇(四):RPC方法注册及调用-更轻量的服务接口提供方式
RPC机制通过前后端的`callAsync`方法实现了高效的数据交互。后端通过`Meteor.methods()`注册方法,支持异步操作;前端使用`callAsync`调用后端方法,代码更简洁、易读。本文详细介绍了Methods注册机制、异步支持及最佳实践。
|
1月前
|
人工智能 前端开发 JavaScript
前端大模型入门(二):掌握langchain的核心Runnable接口
Langchain.js 是 Langchain 框架的 JavaScript 版本,专为前端和后端 JavaScript 环境设计。最新 v0.3 版本引入了强大的 Runnable 接口,支持灵活的执行方式和异步操作,方便与不同模型和逻辑集成。本文将详细介绍 Runnable 接口,并通过实现自定义 Runnable 来帮助前端人员快速上手。
|
1月前
|
JavaScript 前端开发 Python
django接收前端vue传输的formData图片数据
django接收前端vue传输的formData图片数据
38 4
|
1月前
|
前端开发 小程序 Java
java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机
这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。
20 1
|
1月前
|
前端开发 JavaScript 编译器
不走弯路,纯前端如何把图片导出成视频!
【10月更文挑战第3天】不走弯路,纯前端如何把图片导出成视频!
44 3
|
1月前
|
JavaScript 前端开发 编译器
吐血整理:纯前端如何实现批量dom转图片,并下载成压缩包
【10月更文挑战第2天】吐血整理:纯前端如何实现批量dom转图片,并下载成压缩包
55 2
|
2月前
|
前端开发
前端之图片操作
前端之图片操作
|
1月前
|
存储 人工智能 前端开发
前端大模型应用笔记(三):Vue3+Antdv+transformers+本地模型实现浏览器端侧增强搜索
本文介绍了一个纯前端实现的增强列表搜索应用,通过使用Transformer模型,实现了更智能的搜索功能,如使用“番茄”可以搜索到“西红柿”。项目基于Vue3和Ant Design Vue,使用了Xenova的bge-base-zh-v1.5模型。文章详细介绍了从环境搭建、数据准备到具体实现的全过程,并展示了实际效果和待改进点。
133 2
|
1月前
|
JavaScript 前端开发 程序员
前端学习笔记——node.js
前端学习笔记——node.js
43 0
下一篇
无影云桌面