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



目录
相关文章
|
2月前
|
前端开发
调试前端时,在浏览器上修改参数并重新调用接口
有时候我们的页面点击过了,但是接口出问题,想修改参数再调用一次,一般是用apiPost工具把接口复制,再加上token和参数,但是这样非常的效率比较低。
42 0
|
4月前
|
前端开发 数据库 Python
使用 Python 的 Web 框架(如 Django 或 Flask)来建立后端接口,用于处理用户的请求,从数据库中查找答案并返回给前端界面
【1月更文挑战第13天】使用 Python 的 Web 框架(如 Django 或 Flask)来建立后端接口,用于处理用户的请求,从数据库中查找答案并返回给前端界面
92 7
|
2月前
|
前端开发
前端实现视频或者图片直链下载
前端实现视频或者图片直链下载
55 0
|
2月前
|
前端开发 JavaScript C++
【Vue3】解锁Vue3黑科技:探索接口、泛型和自定义类型的前端奇迹
【Vue3】解锁Vue3黑科技:探索接口、泛型和自定义类型的前端奇迹
|
3月前
|
前端开发 JavaScript
前端 JavaScript 与 HTML 怎么实现交互
前端 JavaScript 与 HTML 怎么实现交互
|
3月前
|
前端开发 JavaScript 小程序
前端图片转base64 方法
前端图片转base64 方法
45 0
|
4月前
|
前端开发 JavaScript 定位技术
Flutter vs 前端 杂谈:SliverAppBar、手动实现Appbar、前端Html+JS怎么实现滚动变化型Appbar - 比较
Flutter vs 前端 杂谈:SliverAppBar、手动实现Appbar、前端Html+JS怎么实现滚动变化型Appbar - 比较
33 0
|
4月前
|
前端开发
elementui-upload组件自定义样式上传(upload中常用的属性,但是网络上却找不到教程)(解决bug删除之后再次上传会上传删除的图片)专注后端工程师的前端速成
elementui-upload组件自定义样式上传(upload中常用的属性,但是网络上却找不到教程)(解决bug删除之后再次上传会上传删除的图片)专注后端工程师的前端速成
70 0
|
4月前
|
前端开发
前端常用PS技巧总结之更换图片背景图片
前端常用PS技巧总结之更换图片背景图片
30 0
|
4月前
|
存储 前端开发 文件存储
前端常用PS技巧总结之将图片背景透明化
前端常用PS技巧总结之将图片背景透明化
38 0