Capitalisation boursière: $2.7991T -6.33%
Volume(24h): $182.2077B 63.84%
Indice de peur et de cupidité:

38 - Peur

  • Capitalisation boursière: $2.7991T -6.33%
  • Volume(24h): $182.2077B 63.84%
  • Indice de peur et de cupidité:
  • Capitalisation boursière: $2.7991T -6.33%
Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos
Top Cryptospedia

Choisir la langue

Choisir la langue

Sélectionnez la devise

Cryptos
Les sujets
Cryptospedia
Nouvelles
Cryptosopique
Vidéos

Comment créer un contrat NFT (ERC-721) à partir de zéro ?

ERC-721 mandates unique token IDs, owner tracking, and Transfer events; optional metadata via tokenURI enables rich NFTs—implemented securely using OpenZeppelin contracts.

Jan 22, 2026 at 03:40 am

Comprendre les spécifications de la norme ERC-721

1. ERC-721 définit un ensemble de fonctions et d'événements obligatoires que tout contrat conforme doit mettre en œuvre, notammentownerOf , safeTransferFrom et approuver .

2. La norme impose des identifiants de jeton uniques : chaque NFT doit avoir un identifiant uint256 distinct mappé à exactement un propriétaire à un moment donné.

3. La prise en charge des métadonnées est facultative mais largement adoptée ; la fonction tokenURI renvoie un URI pointant vers JSON contenant des liens de nom, de description et d'image.

4. Les événements de transfert doivent émettre des paramètres Transfer with from, to et tokenId pour garantir la compatibilité du portefeuille et de l'explorateur.

5. La prise en charge de l'énumération n'est pas requise par la base ERC-721, mais de nombreuses implémentations ajoutent totalSupply et tokenByIndex pour l'indexation du marché.

Configuration de l'environnement de développement

1. Installez Node.js et npm pour gérer les dépendances telles que Hardhat ou Foundry pour la compilation et les tests locaux.

2. Initialisez un nouveau projet avec npm init -y et installez OpenZeppelin Contracts via npm install @openzeppelin/contracts .

3. Configurez le fichier de configuration Hardhat pour vous connecter à Sepolia ou au réseau Anvil local pour la simulation de déploiement.

4. Créez un fichier Solidity nommé MyNFT.sol dans le répertoire des contrats et importez les modules ERC721 et Ownable d'OpenZeppelin.

5. Définissez les arguments du constructeur tels que le nom et le symbole, puis appelez le constructeur ERC721 parent avec ces valeurs.

Rédaction de la logique contractuelle de base

1. Ajoutez une variable d'état _baseTokenURI pour stocker le chemin racine des métadonnées, mis à jour uniquement par le propriétaire du contrat.

2. Remplacez la fonction tokenURI pour concaténer _baseTokenURI avec la chaîne tokenId, en vous assurant que les points de terminaison IPFS ou HTTP sont correctement résolus.

3. Implémentez une fonction menthe qui utilise _safeMint pour attribuer de nouveaux jetons exclusivement à msg.sender et incrémenter les compteurs internes.

4. Introduisez des modificateurs onlyOwner sur les fonctions sensibles telles que setBaseURI pour empêcher toute manipulation non autorisée des métadonnées.

5. Incluez un remplacement supportsInterface pour renvoyer true pour les ID d'interface 0x80ac58cd (ERC-721) et 0x5b5e139f (métadonnées ERC-721).

Compilation et déploiement sur Testnet

1. Exécutez la compilation npx hardhat pour générer l'ABI et le bytecode ; vérifiez qu’aucune erreur de syntaxe ou d’héritage n’apparaît.

2. Écrivez un script de déploiement qui appelle le constructeur de contrat avec « CryptoPanda » et « CPANDA » comme arguments.

3. Utilisez npx hardhat run scripts/deploy.js --network sepolia pour diffuser la transaction après avoir financé l'adresse du déployeur.

4. Vérifiez le contrat sur Etherscan Sepolia en utilisant la même version du compilateur et les mêmes paramètres d'optimisation que ceux utilisés lors de la compilation.

5. Interagissez avec le contrat déployé à l'aide des interfaces dApp « Write as Proxy » d'Etherscan ou connectées à MetaMask pour déclencher la frappe et les transferts.

Foire aux questions

Q : Puis-je modifier le tokenURI après le minting ? R : Oui, si votre contrat le permet via une fonction de configuration réservée au propriétaire, mais sa modification affecte rétroactivement tous les jetons précédemment émis, à moins que vous ne stockiez les URI par jeton.

Q : Que se passe-t-il si deux jetons partagent le même identifiant ? R : Le contrat sera annulé lors de la création en raison de contrôles de mappage en double appliqués par la validation de mappage _owners d'OpenZeppelin.

Q : Le coût du gaz est-il plus élevé pour l’ERC-721 que pour l’ERC-20 ? R : Oui : les opérations ERC-721 nécessitent des écritures de stockage individuelles par ID de jeton, ce qui entraîne une consommation de gaz considérablement plus élevée pour la frappe et le transfert.

Q : Dois-je inscrire des redevances dans le contrat ? R : Non : les redevances ne font pas partie de la spécification ERC-721. Des plates-formes comme OpenSea lisent les informations sur les redevances à partir de la fonction royaltiesInfo si elles sont implémentées via ERC-2981.

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.

Connaissances connexes

Comment exécuter un message inter-chaînes avec un contrat LayerZero ?

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 ?

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 ?

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é ?

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 ?

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 ?

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 ?

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 ?

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 ?

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é ?

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 ?

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 ?

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

User not found or password invalid

Your input is correct