使用Node.js實(shí)現(xiàn)base64和png文件相互轉(zhuǎn)換的方法
前天瀏覽技術(shù)博客,看到大廠面試題型中有使用nodejs實(shí)現(xiàn)base64和圖片文件相互轉(zhuǎn)換的例子,剛好近期要開發(fā)這個(gè)功能,暫時(shí)記錄下來,下周開發(fā)完成再做一個(gè)補(bǔ)充。
1. 將base64 轉(zhuǎn)換為圖片文件,這里舉例用的png文件
const fs = require('fs');
const path = 'xxx/'+ Date.now() +'.png';
const base64 = data.replace(/^data:image\/\w+;base64,/,""); //去掉圖片base64碼前面部分data:image/png;base64
// new Buffer 操作權(quán)限太大,v6.0后使用Buffer.from()創(chuàng)建構(gòu)造函數(shù)
const dataBuffer = new Buffer(base64, 'base64'); //把base64碼轉(zhuǎn)成buffer對象,
fs.writeFile(path, dataBuffer, function(err){//用fs寫入文件
if(err){
console.log(err);
}else{
console.log('寫入成功!');
}
})
創(chuàng)建Buffer
類型:類整數(shù)數(shù)組
原因:JavaScript 語言自身只有字符串?dāng)?shù)據(jù)類型,沒有二進(jìn)制數(shù)據(jù)類型。但在處理像TCP流或文件流時(shí)(base64即文件流),必須使用到二進(jìn)制數(shù)據(jù)。因此在 Node.js中,定義了一個(gè)Buffer類,該類用來創(chuàng)建一個(gè)專門存放二進(jìn)制數(shù)據(jù)的緩存區(qū)。
常用
const buf = Buffer.from(string, encoding); // 返回一個(gè)被 string,編碼格式是base64(默認(rèn)編碼格式是utf-8)的值初始化的新的 Buffer 實(shí)例 buf.toJSON(); // 轉(zhuǎn)換為JSON對象 buf.write(string, offset, length, encoding) // 寫入node緩存區(qū) buf.toString(encoding, start, end) // 從緩存區(qū)讀取數(shù)據(jù)
2.將圖片文件轉(zhuǎn)換成base64
const fs = require("fs");
const util = require("util");
const imageData = await util.promisify(fs.readFileSync(fileUrl)); // 例:xxx/xx/xx.png
const imageBase64 = imageData.toString("base64");
const imagePrefix = "data:image/png;base64,";
console.log(imagePrefix + imageBase64);
知識點(diǎn)補(bǔ)充:NodeJs將任意文件轉(zhuǎn)換為base64格式
很多圖片音頻等文件,有時(shí)候可能需要讀取到數(shù)據(jù)中或者放到單文件的HTML中時(shí),將它們轉(zhuǎn)換成為base64格式是一個(gè)好方法,nodejs可以很方便的把文件轉(zhuǎn)換為base64格式:
需要依賴庫“fs”,“path”,“mime-types”,庫mime-types可通過npm安裝,具體的代碼如下:
const fs = require('fs');
const path = require('path');
const mineType = require('mime-types');
let filePath = path.resolve('your/file/path');
let data = fs.readFileSync(filePath);
data = new Buffer(data).toString('base64');
let base64 = 'data:' + mineType.lookup(filePath) + ';base64,' + data;
fs.writeFileSync(path.resolve('your/save/file/path'), base64);
在你保存的文件中就有該文件的base64格式數(shù)據(jù)了,實(shí)際使用中可以直接使用轉(zhuǎn)換的base64數(shù)據(jù),然后可以放到img、audio或者video標(biāo)簽上使用。
總結(jié)
到此這篇關(guān)于使用Node.js實(shí)現(xiàn)base64和png文件相互轉(zhuǎn)換的文章就介紹到這了,更多相關(guān)nodejs base64和png轉(zhuǎn)換內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
node.js學(xué)習(xí)之交互式解釋器REPL詳解
Node.js REPL(Read Eval Print Loop:交互式解釋器) 表示一個(gè)電腦的環(huán)境,類似Window 系統(tǒng)的終端或 Unix/Linux shell,我們可以在終端中輸入命令,并接收系統(tǒng)的響應(yīng)。下面這篇文章我們就來詳細(xì)的介紹下關(guān)于node.js交互式解釋器REPL的內(nèi)容,有需要的朋友們可以參考借鑒。2016-12-12
如何使用Node.js爬取任意網(wǎng)頁資源并輸出PDF文件到本地
這篇文章主要介紹了使用Node.js爬取任意網(wǎng)頁資源并輸出高質(zhì)量PDF文件到本地,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,下面小編就來和大家一起學(xué)習(xí)吧2019-06-06
npm install常見錯(cuò)誤類型及對應(yīng)的解決方案
在前端開發(fā)中,npm是最常用的包管理工具,通過 npm install 命令,開發(fā)者可以輕松地安裝項(xiàng)目所需的依賴包,然而,在實(shí)際使用過程中,npm install 可能會因?yàn)楦鞣N原因而報(bào)錯(cuò),本文將詳細(xì)介紹一些常見的 npm install 錯(cuò)誤類型、發(fā)生原因及其對應(yīng)的解決方案,需要的朋友可以參考下2025-03-03
Nodejs 中的 Buffer 類的創(chuàng)建與基本使用
這篇文章主要為大家介紹了Nodejs中Buffer的使用示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-10-10
NodeJS 創(chuàng)建目錄和文件的方法實(shí)例分析
這篇文章主要介紹了NodeJS 創(chuàng)建目錄和文件的方法,涉及node.js中fs模塊mkdir、writeFile及目錄判斷existsSync等方法的功能與相關(guān)使用技巧,需要的朋友可以參考下2023-04-04

