To upload a base64 image to ipfs, convert the base64 image to a blob using the fetch()
method and then you can able to upload the base64 image to IPFS.
Take the sort of example of uploading a base64 image to IPFS.
const response = await fetch(base64Image);
const blob = await response.blob();
const file = new File([blob], "file.png", { type: "image/png" });
const imghash = await ipfs.add(file);
Today, I’m going to show you How do I upload base64 images to ipfs, as above mentioned here, I’m going to use the fetch()
method to make files uploadable and ipfs-http-client
package to upload file in IPFS.
Let’s start today’s tutorial how do you upload base64 images to ipfs?
In this example, we will do
- Install the
ipfs-http-client
package - Take the example of base64 image and upload it to IPFS
- Show the uploaded image on the screen
import React, { useState, useEffect } from "react";
import { create } from "ipfs-http-client";
const ifpsConfig = {
host: "ipfs.infura.io",
port: 5001,
protocol: "https"
};
const ipfs = create(ifpsConfig);
const base64Image =
"";
export default function App() {
const [hash, setHash] = useState(
"QmR4uT3fuqzbrNyAobMFmANtaSkz1MY5V36JikKUJ78ytf"
);
const uploadBase64Image = async () => {
const response = await fetch(base64Image);
const blob = await response.blob();
const file = new File([blob], "file.png", { type: "image/png" });
const imghash = await ipfs.add(file);
console.log(imghash);
setHash(imghash.path);
};
return (
<div className="App">
<button onClick={() => uploadBase64Image()}>Upload</button>
<img src={`https://ipfs.infura.io/ipfs/${hash}`} />
</div>
);
}
In the above example, we uploaded the base64 image to IPFS and retrieved it after uploading done and showing it on the screen.
I hope it helps you, All the best 👍.