-
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%
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) までご連絡ください。速やかに削除させていただきます。
- ビットコイン、eCash フォーク、Airdrop のダイナミクス: 暗号通貨の最新の論争を深く掘り下げる
- 2026-05-03 12:55:01
- コンセンサス 2026 マイアミ: Web3、ブロックチェーン、暗号通貨、NFT、メタバース、カンファレンス、5 月 5 日 — ウォール街とデジタル フロンティアが出会う場所
- 2026-05-02 12:45:01
- FRBが金利を据え置き、地政学的な緊張の中、ビットコイン価格の下落を引き起こす
- 2026-05-01 06:45:01
- ビットコインマイナーが送電網を電化:オハイオ州のガス工場買収がデジタルゴールドの新時代を加速
- 2026-05-01 00:45:01
- MegaETH の MEGA トークンがビッグアップルに到達: リアルタイム ブロックチェーンの新しいパフォーマンス ベンチマークを設定
- 2026-05-01 00:55:01
- ソラナの滑りやすい坂道: 価格予測は抵抗力の損失とさらなる下落の可能性を示している
- 2026-05-01 06:45:01
関連知識
Bybit で BTC 取引を行う場合、リニア永久契約とインバース永久契約のどちらを選択すればよいですか?
2026-06-06 02:54:55
契約決済の仕組み1. Bybit のリニア無期限契約は USDT で決済されます。これは、すべての損益計算、証拠金要件、清算閾値がステーブルコイン単位で表示されることを意味します。 2. 逆永久契約は BTC 自体で決済されるため、すべての取引はトレーダーの BTC 残高に直接影響します。利益があれ...
Bybit で 1 日の最大損失を制限するリスク管理ルールを設定するにはどうすればよいですか?
2026-06-04 16:40:15
アカウントレベルの損失制限の設定1. 2 要素認証を使用して、Web またはモバイル アプリケーション経由で Bybit アカウントにログインします。 2. 「資産」セクションに移動し、左側のメニューから「リスク管理」を選択します。 3. 「日次損失制限」を選択し、機能をオンに切り替えてコントロール...
Binance でポートフォリオ証拠金モードを有効にして証拠金要件を減らすにはどうすればよいですか?
2026-06-05 04:59:43
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、ブロックごとに流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の...
オープン先物ポジションをクローズせずに Binance から Bybit に移行するにはどうすればよいですか?
2026-06-04 03:59:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
米国における仮想通貨先物取引の利益による税金への影響をどのように処理すればよいでしょうか?
2026-05-29 18:19:59
Bitcoin 半減力学1. Bitcoin のプロトコルでは、ブロック報酬を通じて新しいユニットが導入され、2,100 万コインの固定供給上限が強制されます。 2. 210,000 ブロックごと、つまり約 4 年ごとに、ブロック報酬は半分に減ります。これは半減として知られるプロセスです。 3. 最...
Bybit 取引ボット マーケットプレイスを使用して収益性の高い先物戦略を見つけるにはどうすればよいですか?
2026-06-02 04:39:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
Bybit で BTC 取引を行う場合、リニア永久契約とインバース永久契約のどちらを選択すればよいですか?
2026-06-06 02:54:55
契約決済の仕組み1. Bybit のリニア無期限契約は USDT で決済されます。これは、すべての損益計算、証拠金要件、清算閾値がステーブルコイン単位で表示されることを意味します。 2. 逆永久契約は BTC 自体で決済されるため、すべての取引はトレーダーの BTC 残高に直接影響します。利益があれ...
Bybit で 1 日の最大損失を制限するリスク管理ルールを設定するにはどうすればよいですか?
2026-06-04 16:40:15
アカウントレベルの損失制限の設定1. 2 要素認証を使用して、Web またはモバイル アプリケーション経由で Bybit アカウントにログインします。 2. 「資産」セクションに移動し、左側のメニューから「リスク管理」を選択します。 3. 「日次損失制限」を選択し、機能をオンに切り替えてコントロール...
Binance でポートフォリオ証拠金モードを有効にして証拠金要件を減らすにはどうすればよいですか?
2026-06-05 04:59:43
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、ブロックごとに流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の...
オープン先物ポジションをクローズせずに Binance から Bybit に移行するにはどうすればよいですか?
2026-06-04 03:59:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
米国における仮想通貨先物取引の利益による税金への影響をどのように処理すればよいでしょうか?
2026-05-29 18:19:59
Bitcoin 半減力学1. Bitcoin のプロトコルでは、ブロック報酬を通じて新しいユニットが導入され、2,100 万コインの固定供給上限が強制されます。 2. 210,000 ブロックごと、つまり約 4 年ごとに、ブロック報酬は半分に減ります。これは半減として知られるプロセスです。 3. 最...
Bybit 取引ボット マーケットプレイスを使用して収益性の高い先物戦略を見つけるにはどうすればよいですか?
2026-06-02 04:39:47
Bitcoin 半減力学1. Bitcoin のプロトコルは、ブロック報酬が約 210,000 ブロックごとに半分になる固定発行スケジュールを強制します。 2. このイベントはおよそ 4 年ごとに発生し、流通する新しい BTC の数を直接減少させます。 3. マイナーは、2020 年の半減期の時点で...
すべての記事を見る














