-
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%
Comment rédiger votre premier contrat intelligent avec Solidity ? (Tutoriel étape par étape)
Set up Node.js, Truffle, and Ganache; write an ERC-20 token using OpenZeppelin; compile, deploy locally, and test via Truffle console and JavaScript.
Jan 17, 2026 at 12:00 am
Configuration de l'environnement de développement
1. Installez Node.js et npm pour gérer les dépendances requises pour les outils Solidity.
2. Utilisez npm pour installer Truffle à l'échelle mondiale – un cadre de développement largement adopté pour les contrats intelligents basés sur Ethereum.
3. Installez Ganache en tant que blockchain personnelle pour les tests locaux ; il fournit des comptes privés avec de l'ETH préfinancé.
4. Configurez un nouveau projet Truffle en utilisant truffle init pour générer des répertoires essentiels tels que contracts/ , migrations/ et test/ .
5. Vérifiez l'intégrité de l'installation en exécutant la version truffle et en confirmant la compatibilité avec le compilateur Solidity v0.8.x ou supérieur.
Rédaction d'un contrat de jeton de base
1. Créez un nouveau fichier nommé MyToken.sol dans le dossier contracts/ .
2. Déclarez le pragma de la version Solidity : pragma solidity ^0.8.20 ; pour garantir un comportement de compilation déterministe.
3. Importez l'implémentation ERC-20 d'OpenZeppelin : importez '@openzeppelin/contracts/token/ERC-20/ERC-20.sol' ;
4. Définissez l'héritage du contrat : le contrat MyToken est ERC20 { ... } et initialisez le nom, le symbole et l'offre totale dans le constructeur.
5. Ajoutez une fonction menthe réservée au propriétaire à l'aide du modificateur onlyOwner de la bibliothèque AccessControl d'OpenZeppelin.
Compilation et déploiement du contrat
1. Écrivez un script de migration dans migrations/2_deploy_contracts.js pour instancier et déployer MyToken avec 1 million de jetons.
2. Exécutez la compilation truffle pour générer l'ABI et le bytecode ; confirmez qu’aucune erreur de syntaxe ou d’incompatibilité de version n’apparaît.
3. Lancez Ganache et copiez l'URL de son serveur RPC (par exemple, http://127.0.0.1:7545) dans truffle-config.js sous le réseau de développement .
4. Exécutez truffle migrate --network development pour déployer le contrat et enregistrer les hachages de transaction et les adresses du contrat.
5. Confirmez le succès du déploiement en vérifiant le journal des transactions de Ganache et en vérifiant que l'adresse du contrat apparaît dans la sortie de la console.
Interagir via Truffle Console
1. Démarrez la console Truffle connectée à Ganache : truffle console --network development .
2. Récupérez l'instance déployée : let instance = wait MyToken.deployed();
3. Interrogez l’offre totale à l’aide de (await instance.totalSupply()).toString() – attendez-vous à ce que la sortie corresponde à la valeur initiale.
4. Transférer des jetons entre comptes : wait instance.transfer('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5', '1000') .
5. Validez les changements de solde avec (await instance.balanceOf('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5')).toString() .
Test avec JavaScript
1. Créez test/mytoken.js contenant des cas de test de style Mocha pour les fonctionnalités de base.
2. Utilisez contract() pour définir le contexte de test et les blocs it() pour affirmer des comportements tels que la frappe, le transfert et l'émission d'événements.
3. Affirmez les journaux d'événements corrects avec assert.equal(receipt.logs[0].event, 'Transfer') après avoir appelé le transfert.
4. Testez les conditions de réversion : essayez de transférer plus que le solde et vérifiez que le retour est lancé à l'aide de l'utilitaire expectRevert .
5. Exécutez des tests avec truffle test et confirmez que toutes les assertions sont réussies sans délai d'attente ni exceptions d'exécution.
Foire aux questions
Q : Puis-je déployer un contrat Solidity sans utiliser Truffle ? R : Oui. Les alternatives incluent Hardhat, Remix IDE ou des appels directs web3.js avec bytecode compilé et ABI.
Q : Que se passe-t-il si j'oublie le mot-clé payable sur une fonction qui reçoit de l'ETH ? R : La fonction annulera toute transaction tentant d'envoyer de l'ETH, ce qui entraînera un échec d'exécution et une consommation de gaz.
Q : Est-il sûr d'utiliser tx.origin pour le contrôle d'accès ? R : Non. tx.origin peut être manipulé via des contrats de phishing et ne doit jamais remplacer msg.sender dans les contrôles d'autorisation.
Q : Comment puis-je vérifier le code source de mon contrat sur Etherscan ? R : Soumettez la source exacte de Solidity, la version du compilateur, les paramètres d'optimisation et les arguments du constructeur via le formulaire de vérification d'Etherscan.
Clause de non-responsabilité:info@kdj.com
Les informations fournies ne constituent pas des conseils commerciaux. kdj.com n’assume aucune responsabilité pour les investissements effectués sur la base des informations fournies dans cet article. Les crypto-monnaies sont très volatiles et il est fortement recommandé d’investir avec prudence après une recherche approfondie!
Si vous pensez que le contenu utilisé sur ce site Web porte atteinte à vos droits d’auteur, veuillez nous contacter immédiatement (info@kdj.com) et nous le supprimerons dans les plus brefs délais.
-
RAIN Échangez maintenant$0.007852
113.00%
-
PIPPIN Échangez maintenant$0.06097
51.96%
-
PARTI Échangez maintenant$0.1396
42.04%
-
WAVES Échangez maintenant$0.9141
41.69%
-
ARC Échangez maintenant$0.04302
35.73%
-
HONEY Échangez maintenant$0.01029
21.80%
- Choix du président de la Fed par Trump : Kevin Warsh intensifie ses efforts, Wall Street surveille
- 2026-01-30 22:10:06
- Le rêve d'or numérique de Bitcoin testé alors que les changements du marché et les nouvelles crypto-monnaies prennent feu
- 2026-01-30 22:10:06
- Binance double sa mise : le fonds SAFU se tourne entièrement vers Bitcoin, signalant une profonde conviction
- 2026-01-30 22:05:01
- Les résultats du quatrième trimestre de Chevron montrent un BPA supérieur malgré un déficit de revenus et les yeux rivés sur la croissance future
- 2026-01-30 22:05:01
- Le méga mouvement de Bitcoin en 2026 : naviguer dans la volatilité vers une nouvelle ère
- 2026-01-30 22:00:01
- Perspectives de prix de Cardano (ADA) : naviguer dans les tranchées d’un potentiel marché baissier en 2026
- 2026-01-30 22:00:01
Connaissances connexes
Comment exécuter un message inter-chaînes avec un contrat LayerZero ?
Jan 18,2026 at 01:19pm
Comprendre l'architecture LayerZero 1. LayerZero fonctionne comme un protocole d'interopérabilité léger et sans autorisation qui permet la com...
Comment mettre en œuvre EIP-712 pour la vérification sécurisée des signatures ?
Jan 20,2026 at 10:20pm
Présentation de l'EIP-712 et objectif principal 1. EIP-712 définit une norme pour le hachage et la signature de données structurées typées dans le...
Comment se qualifier pour les parachutages en interagissant avec de nouveaux contrats ?
Jan 24,2026 at 09:00pm
Comprendre les exigences d'interaction contractuelle 1. La plupart des campagnes de largage nécessitent une interaction directe avec des contrats ...
Comment surveiller un contrat intelligent pour les alertes de sécurité ?
Jan 21,2026 at 07:59am
Outils de surveillance en chaîne 1. Les explorateurs de blockchain comme Etherscan et Blockscout permettent une inspection en temps réel du bytecode d...
Comment mettre en place et financer un contrat de paiements automatisés ?
Jan 26,2026 at 08:59am
Comprendre le déploiement de contrats intelligents 1. Les développeurs doivent sélectionner une plate-forme blockchain compatible telle que Ethereum, ...
Comment utiliser les contrats OpenZeppelin pour créer des dApps sécurisées ?
Jan 18,2026 at 11:19am
Comprendre les principes fondamentaux des contrats OpenZeppelin 1. OpenZeppelin Contracts est une bibliothèque de composants de contrats intelligents ...
Comment exécuter un message inter-chaînes avec un contrat LayerZero ?
Jan 18,2026 at 01:19pm
Comprendre l'architecture LayerZero 1. LayerZero fonctionne comme un protocole d'interopérabilité léger et sans autorisation qui permet la com...
Comment mettre en œuvre EIP-712 pour la vérification sécurisée des signatures ?
Jan 20,2026 at 10:20pm
Présentation de l'EIP-712 et objectif principal 1. EIP-712 définit une norme pour le hachage et la signature de données structurées typées dans le...
Comment se qualifier pour les parachutages en interagissant avec de nouveaux contrats ?
Jan 24,2026 at 09:00pm
Comprendre les exigences d'interaction contractuelle 1. La plupart des campagnes de largage nécessitent une interaction directe avec des contrats ...
Comment surveiller un contrat intelligent pour les alertes de sécurité ?
Jan 21,2026 at 07:59am
Outils de surveillance en chaîne 1. Les explorateurs de blockchain comme Etherscan et Blockscout permettent une inspection en temps réel du bytecode d...
Comment mettre en place et financer un contrat de paiements automatisés ?
Jan 26,2026 at 08:59am
Comprendre le déploiement de contrats intelligents 1. Les développeurs doivent sélectionner une plate-forme blockchain compatible telle que Ethereum, ...
Comment utiliser les contrats OpenZeppelin pour créer des dApps sécurisées ?
Jan 18,2026 at 11:19am
Comprendre les principes fondamentaux des contrats OpenZeppelin 1. OpenZeppelin Contracts est une bibliothèque de composants de contrats intelligents ...
Voir tous les articles














