概要
↓のように、img
タグのsrc
がbase64エンコーディングされていた場合に、Nodejsでjpegなどの画像ファイルに変換する方法について記載してます。
解決したコード
-
data:image/jpeg;base64,
の部分を取り除く。 -
fs.writeFile
メソッドにエンコーディングを指定する。
import fs from "fs";
const base64Str = "data:image/jpeg;base64,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"
.replace("data:image/jpeg;base64,","");
fs.promises.writeFile("test.jpeg", base64Str, { encoding: "base64" });