前天瀏覽技術(shù)博客,看到大廠面試題型中有使用nodejs實(shí)現(xiàn)base64和圖片文件相互轉(zhuǎn)換的例子,剛好近期要開(kāi)發(fā)這個(gè)功能,暫時(shí)記錄下來(lái),下周開(kāi)發(fā)完成再做一個(gè)補(bǔ)充。
創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括曲水網(wǎng)站建設(shè)、曲水網(wǎng)站制作、曲水網(wǎng)頁(yè)制作以及曲水網(wǎng)絡(luò)營(yíng)銷(xiāo)策劃等。多年來(lái),我們專(zhuān)注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,曲水網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到曲水省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!
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對(duì)象, fs.writeFile(path, dataBuffer, function(err){//用fs寫(xiě)入文件 if(err){ console.log(err); }else{ console.log('寫(xiě)入成功!'); } })
創(chuàng)建Buffer
類(lèi)型:類(lèi)整數(shù)數(shù)組
原因:JavaScript 語(yǔ)言自身只有字符串?dāng)?shù)據(jù)類(lèi)型,沒(méi)有二進(jìn)制數(shù)據(jù)類(lèi)型。但在處理像TCP流或文件流時(shí)(base64即文件流),必須使用到二進(jìn)制數(shù)據(jù)。因此在 Node.js中,定義了一個(gè)Buffer類(lèi),該類(lèi)用來(lái)創(chuàng)建一個(gè)專(zhuān)門(mén)存放二進(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對(duì)象 buf.write(string, offset, length, encoding) // 寫(xiě)入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);
知識(shí)點(diǎn)補(bǔ)充:NodeJs將任意文件轉(zhuǎn)換為base64格式
很多圖片音頻等文件,有時(shí)候可能需要讀取到數(shù)據(jù)中或者放到單文件的HTML中時(shí),將它們轉(zhuǎn)換成為base64格式是一個(gè)好方法,nodejs可以很方便的把文件轉(zhuǎn)換為base64格式:
需要依賴(lài)庫(kù)“fs”,“path”,“mime-types”,庫(kù)mime-types可通過(guò)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)容請(qǐng)搜索創(chuàng)新互聯(lián)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持創(chuàng)新互聯(lián)!