IPFSを利用した分散型ユーザーインターフェース
あなたは素晴らしい新しいdappを作成しました。 そのためのユーザーインターフェースも作成しました。 しかし、あなたのユーザーインターフェースはクラウド上の1つのサーバーにすぎず、誰かがそれを停止させて検閲しようとすることを恐れています。 このチュートリアルでは、ユーザーインターフェースを**Interplanetary File System (IPFS) (opens in a new tab)**上に置くことで検閲を回避する方法を学びます。そうすれば、関心のある誰もが将来のアクセスのためにサーバーにそれをピン留めできるようになります。
Fleek (opens in a new tab)などのサードパーティサービスを使用して、すべての作業を行うこともできます。 このチュートリアルは、たとえ作業量が増えても、自分たちが何をしているのかを十分に理解したい人向けです。
ローカルでの開始
複数のサードパーティIPFSプロバイダー (opens in a new tab)がありますが、テストのためにローカルでIPFSを実行することから始めるのが最善です。
-
IPFSユーザーインターフェース (opens in a new tab)をインストールします。
-
Webサイトのディレクトリを作成します。 Vite (opens in a new tab)を使用している場合は、次のコマンドを使用します。
1pnpm vite build -
IPFS Desktopで、[インポート] > [フォルダー] をクリックし、前の手順で作成したディレクトリを選択します。
-
アップロードしたばかりのフォルダを選択し、[名前の変更] をクリックします。 より意味のある名前を付けます。
-
もう一度選択し、[リンクを共有] をクリックします。 URLをクリップボードにコピーします。
https://ipfs.io/ipfs/QmaCuQ7yN6iyBjLmLGe8YiFuCwnePoKfVu6ue8vLBsLJQJのようなリンクになります。 -
[ステータス] をクリックします。 [詳細設定] タブを展開してゲートウェイアドレスを表示します。 例えば、私のシステムではアドレスは
http://127.0.0.1:8080です。 -
リンク手順のパスとゲートウェイアドレスを組み合わせて、あなたのアドレスを見つけます。 例えば、上記の例では、URLは
http://127.0.0.1:8080/ipfs/QmaCuQ7yN6iyBjLmLGe8YiFuCwnePoKfVu6ue8vLBsLJQJです。 そのURLをブラウザで開いて、あなたのサイトを表示します。
アップロード
これでIPFSを使ってローカルでファイルを提供できるようになりましたが、これはあまりエキサイティングなことではありません。 次のステップは、あなたがオフラインのときに世界中から利用できるようにすることです。
よく知られているピニングサービス (opens in a new tab)がいくつかあります。 そのうちの1つを選びます。 どのサービスを使用するにしても、アカウントを作成し、IPFSデスクトップのコンテンツ識別子 (CID) を提供する必要があります。
個人的には、4EVERLAND (opens in a new tab) が最も使いやすいと思いました。 その手順は次のとおりです。
-
ダッシュボード (opens in a new tab)にアクセスし、ウォレットでログインします。
-
左のサイドバーで [ストレージ] > [4EVER Pin] をクリックします。
-
[アップロード] > [Selected CID] をクリックします。 コンテンツに名前を付け、IPFSデスクトップからCIDを提供します。 現在、CIDは
Qmで始まり、QmaCuQ7yN6iyBjLmLGe8YiFuCwnePoKfVu6ue8vLBsLJQJのようにbase-58でエンコード (opens in a new tab)されたハッシュを表す44文字の英数字が続く文字列ですが、これは変更される可能性 (opens in a new tab)があります。 -
初期ステータスはQueuedです。 Pinnedに変わるまでリロードします。
-
CIDをクリックしてリンクを取得します。 私のアプリケーションはこちら (opens in a new tab)でご覧いただけます。
-
1か月以上ピン留めするには、アカウントを有効化する必要があるかもしれません。 アカウントの有効化には約1ドルかかります。 閉じてしまった場合は、ログアウトしてから再度ログインすると、再び有効化を求められます。
IPFSからの使用
この時点で、あなたはIPFSコンテンツを提供する中央集権型のゲートウェイへのリンクを持っています。 要するに、あなたのユーザーインターフェースは少し安全になったかもしれませんが、まだ検閲耐性はありません。 真の検閲耐性を得るには、ユーザーはIPFSをブラウザから直接 (opens in a new tab)使用する必要があります。
それがインストールされ(そしてデスクトップIPFSが動作していれば)、任意のサイトで/ipfs/<CID> (opens in a new tab)にアクセスすると、そのコンテンツが分散型の方法で提供されます。
欠点
IPFSファイルを確実に削除することはできないため、ユーザーインターフェースを変更している間は、中央集権型のままにするか、IPFS上で可変性を提供するシステムであるInterplanetary Name System (IPNS) (opens in a new tab)を使用するのがおそらく最善です。 もちろん、可変なものは検閲される可能性があります。IPNSの場合は、それに対応する秘密鍵を持つ人物に圧力をかけることで検閲されます。
さらに、一部のパッケージはIPFSとの間に問題を抱えているため、あなたのWebサイトが非常に複雑な場合、これは良い解決策ではないかもしれません。 そしてもちろん、サーバーとの統合に依存するものは、クライアントサイドをIPFSに置くだけでは分散化できません。
結論
イーサリアムがdappのデータベースとビジネスロジックの側面を分散化できるように、IPFSはユーザーインターフェースを分散化できるようにします。 これにより、あなたのdappに対するもう一つの攻撃ベクトルを遮断できます。
私の他の作品はこちらでご覧いただけます (opens in a new tab).
最終更新: 2026年2月25日