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

38 - 恐れ

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

言語を選択する

言語を選択する

通貨の選択

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

Solidity を使用して最初のスマート コントラクトを作成するにはどうすればよいですか? (ステップバイステップのチュートリアル)

Set up Node.js, Truffle, and Ganache; write an ERC-20 token using OpenZeppelin; compile, deploy locally, and test via Truffle console and JavaScript.

2026/01/17 00:00

開発環境のセットアップ

1. Node.js と npm をインストールして、Solidity ツールに必要な依存関係を管理します。

2. npm を使用して Truffle をグローバルにインストールします。Truffle は、イーサリアムベースのスマート コントラクトに広く採用されている開発フレームワークです。

3. ローカルテスト用に個人用ブロックチェーンとして Ganache をインストールします。事前に資金が積まれたETHをプライベートアカウントに提供します。

4. truffle initを使用して新しい Truffle プロジェクトを構成し、 contracts/migrations/test/などの重要なディレクトリを生成します。

5. truffle バージョンを実行し、Solidity コンパイラ v0.8.x 以降との互換性を確認して、インストールの整合性を検証します。

基本的なトークンコントラクトの作成

1. Contracts/フォルダー内にMyToken.solという名前の新しいファイルを作成します。

2. Solidity バージョンのプラグマを宣言します。pragma Solidity ^0.8.20;決定的なコンパイル動作を保証します。

3. OpenZeppelin の ERC-20 実装をインポートします: import '@openzeppelin/contracts/token/ERC-20/ERC-20.sol';

4. コントラクトの継承を定義します。コントラクト MyToken は ERC20 { ... }で、コンストラクターで名前、シンボル、および総供給量を初期化します。

5. OpenZeppelin の AccessControl ライブラリのonlyOwner修飾子を使用して、所有者に制限された mint 関数を追加します。

契約のコンパイルと展開

1. migrations/2_deploy_contracts.jsに移行スクリプトを記述して、100 万個のトークンを使用してMyToken をインスタンス化してデプロイします。

2. truffle コンパイルを実行して ABI とバイトコードを生成します。構文またはバージョンの不一致エラーが表示されないことを確認します。

3. Ganache を起動し、その RPC サーバー URL (例: http://127.0.0.1:7545) を開発ネットワーク下のtruffle-config.jsにコピーします。

4. truffle Migrate --networkdevelopmentを実行してコントラクトをデプロイし、トランザクション ハッシュとコントラクト アドレスを記録します。

5. Ganache のトランザクション ログをチェックし、コントラクト アドレスがコンソール出力に表示されることを確認して、デプロイメントが成功したことを確認します。

Truffle コンソールを介した対話

1. Ganache に接続されている Truffle コンソールを起動します: truffle console --networkdevelopment

2. デプロイされたインスタンスを取得します。 letinstance = await MyToken.deployed();

3. (await instance.totalSupply()).toString()を使用して総供給量をクエリします。初期値と一致する出力が期待されます。

4. アカウント間でトークンを転送します: await instance.transfer('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5', '1000')

5. (await instance.balanceOf('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5')).toString()を使用してバランスの変更を検証します。

JavaScript を使用したテスト

1. コア機能用の Mocha スタイルのテスト ケースを含むtest/mytoken.jsを作成します。

2.contract()を使用してテスト コンテキストを定義し、 it()ブロックを使用してミント、転送、イベント発行などの動作をアサートします。

3. transfer を呼び出した後、assert.equal(receipt.logs[0].event, 'Transfer')を使用して正しいイベント ログをアサートします。

4. 復帰条件をテストします。残高を超える転送を試行し、 expectRevertユーティリティを使用して復帰がスローされることを確認します。

5.トリュフ テストを使用してテストを実行し、すべてのアサーションがタイムアウトや実行時例外なしで合格することを確認します。

よくある質問

Q: Truffle を使用せずに Solidity コントラクトをデプロイできますか? A: はい。代替手段には、Hardhat、Remix IDE、またはコンパイルされたバイトコードと ABI を使用した直接の web3.js 呼び出しが含まれます。

Q: ETH を受け取る関数のpayableキーワードを忘れた場合はどうなりますか? A: この関数は ETH を送信しようとしたトランザクションを元に戻します。その結果、実行は失敗し、ガスが消費されます。

Q: アクセス制御にtx.origin を使用しても安全ですか? A: いいえ。tx.origin はフィッシング コントラクトを介して操作できるため、アクセス許可チェックでmsg.sender を置き換えてはなりません。

Q: Etherscan で契約ソース コードを検証するにはどうすればよいですか? A: Etherscan の検証フォームを通じて、正確な Solidity ソース、コンパイラー バージョン、最適化設定、およびコンストラクター引数を送信してください。

免責事項: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