-
bitcoin $87959.907984 USD
1.34% -
ethereum $2920.497338 USD
3.04% -
tether $0.999775 USD
0.00% -
xrp $2.237324 USD
8.12% -
bnb $860.243768 USD
0.90% -
solana $138.089498 USD
5.43% -
usd-coin $0.999807 USD
0.01% -
tron $0.272801 USD
-1.53% -
dogecoin $0.150904 USD
2.96% -
cardano $0.421635 USD
1.97% -
hyperliquid $32.152445 USD
2.23% -
bitcoin-cash $533.301069 USD
-1.94% -
chainlink $12.953417 USD
2.68% -
unus-sed-leo $9.535951 USD
0.73% -
zcash $521.483386 USD
-2.87%
NFT コントラクト (ERC-721) を最初から作成するにはどうすればよいですか?
ERC-721 mandates unique token IDs, owner tracking, and Transfer events; optional metadata via tokenURI enables rich NFTs—implemented securely using OpenZeppelin contracts.
2026/01/22 03:40
ERC-721標準仕様を理解する
1. ERC-721 は、 ownerOf 、 safeTransferFrom 、 approveなど、準拠するすべての契約が実装する必要がある必須の関数とイベントのセットを定義しています。
2. この標準では、一意のトークン識別子が強制されます。各 NFT は、常に 1 人の所有者にマッピングされた個別の uint256 ID を持たなければなりません。
3. メタデータのサポートはオプションですが、広く採用されています。 tokenURI関数は、名前、説明、画像リンクを含む JSON を指す URI を返します。
4. 転送イベントは、ウォレットとエクスプローラーの互換性を確保するために、from、to、および tokenId パラメーターを使用してTransferを発行する必要があります。
5. 列挙のサポートは基本 ERC-721 では必須ではありませんが、多くの実装ではマーケットプレイスのインデックス付けのためにtotalSupplyとtokenByIndexが追加されています。
開発環境のセットアップ
1. Node.js と npm をインストールして、ローカル コンパイルとテスト用の Hardhat や Foundry などの依存関係を管理します。
2. npm init -yで新しいプロジェクトを初期化し、 npm install @openzeppelin/contractsで OpenZeppelin Contracts をインストールします。
3. 導入シミュレーションのために Sepolia またはローカル Anvil ネットワークに接続するように Hardhat 構成ファイルを構成します。
4. MyNFT.solという名前の Solidity ファイルを契約ディレクトリに作成し、OpenZeppelin のERC721およびOwnableモジュールをインポートします。
5. 名前やシンボルなどのコンストラクター引数を定義し、それらの値を使用して親 ERC721 コンストラクターを呼び出します。
コアコントラクトロジックの作成
1. _baseTokenURI状態変数を追加して、契約所有者のみが更新するメタデータのルート パスを保存します。
2. tokenURI関数をオーバーライドして_baseTokenURI をtokenId 文字列と連結し、IPFS または HTTP エンドポイントが正しく解決されるようにします。
3. _safeMintを使用して新しいトークンを msg.sender に排他的に割り当て、内部カウンターをインクリメントするmint関数を実装します。
4. 不正なメタデータ操作を防ぐために、 setBaseURIなどの機密関数にonlyOwner修飾子を導入します。
5. 0x80ac58cd (ERC-721) および 0x5b5e139f (ERC-721 メタデータ) インターフェイス ID に対して true を返すために、 supportsInterfaceオーバーライドを組み込みます。
テストネットでのコンパイルとデプロイ
1. npx ハードハット コンパイルを実行して ABI とバイトコードを生成します。構文エラーや継承エラーが表示されないことを確認します。
2. 「CryptoPanda」と「CPANDA」を引数としてコントラクト コンストラクターを呼び出すデプロイメント スクリプトを作成します。
3. デプロイヤ アドレスに資金を提供した後、 npx hardware run scripts/deploy.js --network sepoliaを使用してトランザクションをブロードキャストします。
4. コンパイル時に使用したものと同じコンパイラ バージョンと最適化設定を使用して、Etherscan Sepolia 上のコントラクトを確認します。
5. Etherscan の「Write as Proxy」または MetaMask に接続された dApp インターフェイスを使用して、デプロイされたコントラクトと対話し、ミントと転送をトリガーします。
よくある質問
Q: ミント後に tokenURI を変更できますか? A: はい。契約で所有者専用のセッター関数を使用することが許可されている場合は、トークンごとの URI を保存しない限り、それを変更すると、以前に作成されたすべてのトークンに遡及的に影響します。
Q: 2 つのトークンが同じ ID を共有するとどうなりますか? A: OpenZeppelin の_ownersマッピング検証によって強制される重複マッピング チェックにより、コントラクトはミント中に元に戻ります。
Q: ERC-721 のガスコストは ERC-20 よりも高くなりますか? A: はい - ERC-721 操作では、トークン ID ごとに個別のストレージへの書き込みが必要となるため、鋳造と転送のガス消費量が大幅に増加します。
Q: 契約にロイヤルティを導入する必要がありますか? A: いいえ、ロイヤルティは ERC-721 仕様の一部ではありません。 OpenSea などのプラットフォームは、ERC-2981 経由で実装されている場合、 royaltyInfo関数からロイヤルティ情報を読み取ります。
免責事項:info@kdj.com
提供される情報は取引に関するアドバイスではありません。 kdj.com は、この記事で提供される情報に基づいて行われた投資に対して一切の責任を負いません。暗号通貨は変動性が高いため、十分な調査を行った上で慎重に投資することを強くお勧めします。
このウェブサイトで使用されているコンテンツが著作権を侵害していると思われる場合は、直ちに当社 (info@kdj.com) までご連絡ください。速やかに削除させていただきます。
- トランプ大統領がFRB議長に指名:ケビン・ウォーシュ氏がステップアップ、ウォール街も注目
- 2026-01-30 22:10:06
- 市場の変化と新しい仮想通貨の火付け役として、ビットコインのデジタルゴールドの夢が試される
- 2026-01-30 22:10:06
- バイナンスが倍増:SAFUファンドが完全にビットコインに移行、深い確信の表れ
- 2026-01-30 22:05:01
- シェブロンの第 4 四半期決算は、収益不足にもかかわらず EPS が上回ることを示し、将来の成長に期待
- 2026-01-30 22:05:01
- ビットコインの 2026 年の大きな動き: ボラティリティを新しい時代に向けて乗り切る
- 2026-01-30 22:00:01
- カルダノ (ADA) 価格見通し: 2026 年の潜在的な弱気市場の溝を乗り越える
- 2026-01-30 22:00:01
関連知識
LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?
2026-01-18 13:19:39
LayerZero アーキテクチャを理解する1. LayerZero は、信頼できる仲介者やラップされた資産に依存せずにブロックチェーン間の通信を可能にする、軽量で許可のない相互運用性プロトコルとして動作します。 2. 各チェーンに展開されたウルトラ ライト ノード (ULN) を利用して、ブロック...
安全な署名検証のために 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 を構築するにはどうすればよいですか?
2026-01-18 11:19:49
OpenZeppelin コントラクトの基礎を理解する1. OpenZeppelin Contracts は、イーサリアムおよび EVM 互換ブロックチェーン用に構築された、再利用可能なコミュニティ監査済みのスマート コントラクト コンポーネントのライブラリです。 2. ライブラリ内の各コントラクト...
LayerZero コントラクトを使用してクロスチェーン メッセージを実行するにはどうすればよいですか?
2026-01-18 13:19:39
LayerZero アーキテクチャを理解する1. LayerZero は、信頼できる仲介者やラップされた資産に依存せずにブロックチェーン間の通信を可能にする、軽量で許可のない相互運用性プロトコルとして動作します。 2. 各チェーンに展開されたウルトラ ライト ノード (ULN) を利用して、ブロック...
安全な署名検証のために 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 を構築するにはどうすればよいですか?
2026-01-18 11:19:49
OpenZeppelin コントラクトの基礎を理解する1. OpenZeppelin Contracts は、イーサリアムおよび EVM 互換ブロックチェーン用に構築された、再利用可能なコミュニティ監査済みのスマート コントラクト コンポーネントのライブラリです。 2. ライブラリ内の各コントラクト...
すべての記事を見る














