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

  1. Install the ipfs-http-client package
  2. Take the example of base64 image and upload it to IPFS
  3. 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 👍.