Nodejs 使用 Buffer 将图片转为 base64

编程入门 行业动态 更新时间:2024-10-25 22:29:51

Nodejs 使用 Buffer 将<a href=https://www.elefans.com/category/jswz/34/1770705.html style=图片转为 base64"/>

Nodejs 使用 Buffer 将图片转为 base64

一直以为图片转为 base64 很复杂,结果今天看了下 Docusaurus 的 plugin-ideal-image 插件源码,居然只要一行代码就完事了:

const toBase64 = (extMimeType: string, data: Buffer): string =>`data:${extMimeType};base64,${data.toString('base64')}`;

这里说明下,这个插件使用 sharp 对图片进行处理,最后返回的是一个 Buffer 实例,我们先来了解下 Buffer。首先 Buffer 实际上就是一个固定长度的字节类型数组 byte[],可以通过以下方式创建 Buffer

// 创建长度为 10 的 Buffer,每个元素的默认值为 0
const buf1 = Buffer.alloc(10);// 创建长度为 10 的 Buffer
// 每个元素填充为 1
const buf2 = Buffer.alloc(10, 1);// 通过数组创建 Buffer
const buf4 = Buffer.from([1, 2, 3]);// 每个元素会根据 `(value & 255)` 规则转为 0-255 中的值
// 下面这个会得到 [1, 1, 1, 1]
const buf5 = Buffer.from([257, 257.5, -255, '1']);// 通过字符串创建 Buffer
const buf6 = Buffer.from('tést');// 可通过第二个参数指定编码规则,默认 utf8
const buf7 = Buffer.from('tést', 'latin1');

在 Nodejs 中,Buffer 是全局对象,不需要手动导入模块就能使用

Buffer 实例上有一个 toString 方法,这个方法可以根据传入的编码规则将 Buffer 转为字符串:

const buf = Buffer.from('hello world', 'utf8');// 默认 utf8
buf.toString(); // hello world
buf.toString('hex'); // 68656c6c6f20776f726c64
buf.toString('base64'); // aGVsbG8gd29ybGQ=

按照这个思路,我们就可以使用 Buffer 将图片转为 Base64。不过如何创建 Buffer 呢,我们可以使用 fs 模块读取文件,然后调用 Buffer.from 创建 Buffer:

const http = require('node:http');
const fs = require('node:fs');
const path = require('node:path');http.createServer((req, res) => {const readable = fs.readFileSync(path.join(__dirname, './2333.png'), 'binary');res.end(Buffer.from(readable, 'binary').toString('base64'));
}).listen(3000);

参考

Buffer - Node.js 官方文档

更多推荐

Nodejs 使用 Buffer 将图片转为 base64

本文发布于:2023-06-30 14:21:21,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/961745.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:图片   Nodejs   Buffer

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!