時価総額: $2.8213T -5.58%
ボリューム(24時間): $178.7694B 60.91%
恐怖と貪欲の指数:

38 - 恐れ

  • 時価総額: $2.8213T -5.58%
  • ボリューム(24時間): $178.7694B 60.91%
  • 恐怖と貪欲の指数:
  • 時価総額: $2.8213T -5.58%
暗号
トピック
暗号化
ニュース
暗号造園
動画
トップクリプトスペディア

言語を選択する

言語を選択する

通貨の選択

暗号
トピック
暗号化
ニュース
暗号造園
動画

ERC-1155 マルチトークン標準スマート コントラクトを作成するにはどうすればよいですか?

ERC-1155 is an Ethereum token standard enabling efficient, batched management of both fungible and non-fungible tokens in a single smart contract.

2026/01/11 12:39

ERC-1155 の基礎を理解する

1. ERC-1155 は、単一のスマート コントラクト内で複数のトークン タイプ(代替可能および代替不可能の両方)の作成を可能にするイーサリアム ブロックチェーンのトークン標準です。

2. トークンの種類ごとに個別の契約が必要な ERC-20 や ERC-721 とは異なり、ERC-1155 は導入コストを削減し、バッチ操作を通じて管理を簡素化します。

3. ERC-1155 コントラクト内の各トークンは一意のuint256 idによって識別され、残高はアドレスごと、ID ごとに追跡されます。

4. この標準では、 BalanceOfBalanceOfBatchsafeTransferFromsetApprovalForAllなどのコア関数が定義されています。

5. メタデータのサポートは、ERC-1155 メタデータ URI スキームに従います。このスキームでは、ベース URI が設定され、個々のトークン URI は {id} 置換によって導出されます。

開発環境のセットアップ

1. Node.js と npm をインストールして依存関係を管理し、Hardhat や Foundry などのツールを使用して Solidity コードをコンパイルします。

2. npx ハードハットを使用して新しいハードハット プロジェクトを初期化し、 hardhat.config.jsでネットワーク、アカウント、およびコンパイラ設定を構成します。

3. npm install @openzeppelin/contracts経由で OpenZeppelin の ERC-1155 実装を追加し、安全で監査された基本ロジックを継承します。

4. 新しい Solidity ファイル (例: MyERC1155.sol ) を作成し、OpenZeppelin からERC1155Ownableをインポートします。

5. ベース URI を設定し、所有権をデプロイヤーに譲渡するコンストラクターを定義して、承認された関係者のみが後でメタデータ パスを更新できるようにします。

コアトークンロジックの実装

1. _beforeTokenTransferフックをオーバーライドして、カスタム ルールを適用します。たとえば、特定のブロック後のミントを制限したり、メンテナンス期間中の転送を禁止したりします。

2. 所有者のみがアクセスできるmint関数を導入し、 toidamount 、およびdataパラメーターを受け入れて、 _mintを呼び出します。

3. 複数のトークン ID と数量の同時鋳造をサポートするmintBatch関数を追加し、エコシステムのオンボーディングのためのガス効率を向上させます。

4. OpenZeppelin のAccessControlを使用して機密性の高いアクションに対するロールベースのアクセス制御を実装し、ミンター、ポーズ、メタデータ アップデーターのロールを分離します。

5. TransferSingleTransferBatchなどのイベント エミッションを埋め込み、オフチェーン インデクサーと dApp が状態の変更を正しく追跡できるようにします。

メインネットでのデプロイと検証

1. Hardhat の展開タスクを使用して展開スクリプトを作成し、ネットワーク エンドポイント、秘密キー、およびベース URI 文字列を含むコンストラクター引数を指定します。

2. Etherscan の API キーと Hardhat の検証プラグインを使用して、検証のためにソース コードとコンストラクター引数を自動的に送信します。

3. Etherscan でコントラクト アドレスをチェックし、 uri(1)呼び出しが名前、説明、および画像フィールドを含む適切にフォーマットされた JSON エンドポイントを返すことを検証して、デプロイメントが成功したことを確認します。

4. Etherscan の「Write Contract」タブを使用するか、または ethers.js を介してプログラム的にデプロイされたコントラクトを操作して、ミント、承認、および転送の機能をテストします。

5. ベース URI を IPFS または分散ストレージ サービスに保存し、Pinata や Web3.Storage などのサービスを使用して固定して、メタデータ資産の長期的な可用性を保証します。

よくある質問

Q: ERC-1155 契約は NFT と FT の両方を同時に保持できますか? A: はい。単一のトークン ID は、使用状況とアプリケーション ロジックに応じて、代替可能なトークン (残高 > 1) または代替不可能なトークン (残高 = 1) のいずれかを表すことができます。

Q: ERC-1155 コントラクトでトークンを書き込むことは可能ですか? A: はい。開発者は、OpenZeppelin の ERC1155 ベースから_burnまたは_burnBatch を呼び出す書き込み関数を実装し、残高を減らし、適切なイベントを発行できます。

Q: ERC-721 と比較して、ERC-1155 は承認をどのように処理しますか? A: ERC-1155 はsetApprovalForAllによるオペレーターレベルの承認を使用し、トークンごとの承認ではなく、呼び出し元が所有するすべてのトークン ID に対する包括的な許可を第三者に付与します。

Q: OpenSea のようなマーケットプレイスは ERC-1155 トークンをサポートしていますか? A: はい。 OpenSea、Blur、Magic Eden などの主要なプラットフォームは ERC-1155 をサポートしていますが、一部のプラットフォームではバッチ転送に制限が課されたり、アセットを適切にレンダリングするために特定の URI 形式が必要になる場合があります。

免責事項:info@kdj.com

提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。

このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。

関連知識

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

2026-01-18 13:19:39

LayerZero アーキテクチャを理解する1. LayerZero は、信頼できる仲介者やラップされた資産に依存せずにブロックチェーン間の通信を可能にする、軽量で許可のない相互運用性プロトコルとして動作します。 2. 各チェーンに展開されたウルトラ ライト ノード (ULN) を利用して、ブロック...

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

2026-01-20 22:20:26

EIP-712 の概要と主な目的1. EIP-712 は、イーサリアム アプリケーションにおける型付き構造化データのハッシュと署名の標準を定義します。 2. これにより、ウォレットは、署名リクエスト中に未加工の 16 進文字列の代わりに人間が判読できるドメインおよびメッセージ フィールドを表示できる...

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

2026-01-24 21:00:23

契約のやり取りの要件を理解する1. ほとんどのエアドロップ キャンペーンでは、Ethereum、Arbitrum、Base などのサポートされているブロックチェーンにデプロイされたスマート コントラクトとの直接対話が義務付けられています。 2. インタラクションには通常、dApp インターフェースに...

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

2026-01-21 07:59:57

オンチェーン監視ツール1. Etherscan や Blockscout などのブロックチェーン エクスプローラーを使用すると、コントラクト バイトコード、トランザクション ログ、内部呼び出しをリアルタイムで検査できます。 2. オンチェーンデータを信頼する前に、契約の検証ステータスを確認する必要が...

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

2026-01-26 08:59:35

スマートコントラクトの展開を理解する1. 開発者は、ガス効率とセキュリティ要件に基づいて、Ethereum、Polygon、Arbitrum などの互換性のあるブロックチェーン プラットフォームを選択する必要があります。 2. Solidity は、特に定期的な送金や条件付き送金の場合、支払い自動化...

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

2026-01-18 11:19:49

OpenZeppelin コントラクトの基礎を理解する1. OpenZeppelin Contracts は、イーサリアムおよび EVM 互換ブロックチェーン用に構築された、再利用可能なコミュニティ監査済みのスマート コントラクト コンポーネントのライブラリです。 2. ライブラリ内の各コントラクト...

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?

2026-01-18 13:19:39

LayerZero アーキテクチャを理解する1. LayerZero は、信頼できる仲介者やラップされた資産に依存せずにブロックチェーン間の通信を可能にする、軽量で許可のない相互運用性プロトコルとして動作します。 2. 各チェーンに展開されたウルトラ ライト ノード (ULN) を利用して、ブロック...

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

安全な署名検証のために EIP-712 を実装するにはどうすればよいですか?

2026-01-20 22:20:26

EIP-712 の概要と主な目的1. EIP-712 は、イーサリアム アプリケーションにおける型付き構造化データのハッシュと署名の標準を定義します。 2. これにより、ウォレットは、署名リクエスト中に未加工の 16 進文字列の代わりに人間が判読できるドメインおよびメッセージ フィールドを表示できる...

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

新しい契約を交わしてエアドロップの資格を得るにはどうすればよいですか?

2026-01-24 21:00:23

契約のやり取りの要件を理解する1. ほとんどのエアドロップ キャンペーンでは、Ethereum、Arbitrum、Base などのサポートされているブロックチェーンにデプロイされたスマート コントラクトとの直接対話が義務付けられています。 2. インタラクションには通常、dApp インターフェースに...

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

スマート コントラクトのセキュリティ アラートを監視するにはどうすればよいですか?

2026-01-21 07:59:57

オンチェーン監視ツール1. Etherscan や Blockscout などのブロックチェーン エクスプローラーを使用すると、コントラクト バイトコード、トランザクション ログ、内部呼び出しをリアルタイムで検査できます。 2. オンチェーンデータを信頼する前に、契約の検証ステータスを確認する必要が...

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

自動支払いのための契約を設定して資金を調達するにはどうすればよいですか?

2026-01-26 08:59:35

スマートコントラクトの展開を理解する1. 開発者は、ガス効率とセキュリティ要件に基づいて、Ethereum、Polygon、Arbitrum などの互換性のあるブロックチェーン プラットフォームを選択する必要があります。 2. Solidity は、特に定期的な送金や条件付き送金の場合、支払い自動化...

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

OpenZeppelin コントラクトを使用して安全な dApp を構築するにはどうすればよいですか?

2026-01-18 11:19:49

OpenZeppelin コントラクトの基礎を理解する1. OpenZeppelin Contracts は、イーサリアムおよび EVM 互換ブロックチェーン用に構築された、再利用可能なコミュニティ監査済みのスマート コントラクト コンポーネントのライブラリです。 2. ライブラリ内の各コントラクト...

すべての記事を見る

User not found or password invalid

Your input is correct