-
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%
Wie erstelle ich einen NFT-Vertrag (ERC-721) von Grund auf?
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
Grundlegendes zu den ERC-721-Standardspezifikationen
1. ERC-721 definiert eine Reihe obligatorischer Funktionen und Ereignisse, die jeder konforme Vertrag implementieren muss, einschließlich OwnerOf , SafeTransferFrom und Approve .
2. Der Standard erzwingt eindeutige Token-Identifikatoren – jeder NFT muss zu jedem Zeitpunkt eine eindeutige uint256-ID haben, die genau einem Eigentümer zugeordnet ist.
3. Die Unterstützung von Metadaten ist optional, wird aber weit verbreitet; Die tokenURI -Funktion gibt einen URI zurück, der auf JSON verweist und Namen, Beschreibung und Bildlinks enthält.
4. Übertragungsereignisse müssen Übertragung mit den Parametern „von“, „zu“ und „tokenId“ ausgeben, um die Kompatibilität von Wallet und Explorer sicherzustellen.
5. Die Unterstützung der Aufzählung ist für die Basis-ERC-721 nicht erforderlich, aber viele Implementierungen fügen totalSupply und tokenByIndex für die Marktplatzindizierung hinzu.
Entwicklungsumgebung einrichten
1. Installieren Sie Node.js und npm, um Abhängigkeiten wie Hardhat oder Foundry für die lokale Kompilierung und Tests zu verwalten.
2. Initialisieren Sie ein neues Projekt mit npm init -y und installieren Sie OpenZeppelin Contracts über npm install @openzeppelin/contracts .
3. Konfigurieren Sie die Hardhat-Konfigurationsdatei für die Verbindung mit Sepolia oder dem lokalen Anvil-Netzwerk für die Bereitstellungssimulation.
4. Erstellen Sie eine Solidity-Datei mit dem Namen MyNFT.sol im Vertragsverzeichnis und importieren Sie die ERC721- und Ownable -Module von OpenZeppelin.
5. Definieren Sie Konstruktorargumente wie Name und Symbol und rufen Sie dann den übergeordneten ERC721-Konstruktor mit diesen Werten auf.
Schreiben der Kernvertragslogik
1. Fügen Sie eine _baseTokenURI- Statusvariable hinzu, um den Stammpfad für Metadaten zu speichern, der nur vom Vertragseigentümer aktualisiert wird.
2. Überschreiben Sie die tokenURI- Funktion, um _baseTokenURI mit der tokenId-Zeichenfolge zu verketten und sicherzustellen, dass IPFS- oder HTTP-Endpunkte korrekt aufgelöst werden.
3. Implementieren Sie eine Mint- Funktion, die _safeMint verwendet, um neue Token ausschließlich msg.sender zuzuweisen und interne Zähler zu erhöhen.
4. Führen Sie onlyOwner- Modifikatoren für sensible Funktionen wie setBaseURI ein, um unbefugte Metadatenmanipulation zu verhindern.
5. Fügen Sie eine „supportsInterface“ -Überschreibung ein, um „true“ für die Schnittstellen-IDs 0x80ac58cd (ERC-721) und 0x5b5e139f (ERC-721 Metadaten) zurückzugeben.
Kompilieren und Bereitstellen im Testnet
1. Führen Sie die Npx-Hardhat-Kompilierung aus, um ABI und Bytecode zu generieren. Stellen Sie sicher, dass keine Syntax- oder Vererbungsfehler auftreten.
2. Schreiben Sie ein Bereitstellungsskript, das den Vertragskonstruktor mit „CryptoPanda“ und „CPANDA“ als Argumenten aufruft.
3. Verwenden Sie npx hardhat run scripts/deploy.js --network sepolia, um die Transaktion nach der Finanzierung der Deployer-Adresse zu übertragen.
4. Überprüfen Sie den Vertrag auf Etherscan Sepolia mit derselben Compilerversion und denselben Optimierungseinstellungen, die während der Kompilierung verwendet wurden.
5. Interagieren Sie mit dem bereitgestellten Vertrag über Etherscans „Write as Proxy“ oder MetaMask-verbundene dApp-Schnittstellen, um Prägung und Übertragungen auszulösen.
Häufig gestellte Fragen
F: Kann ich den TokenURI nach dem Prägen ändern? A: Ja – wenn Ihr Vertrag dies über eine Setter-Funktion nur für den Eigentümer zulässt. Eine rückwirkende Änderung wirkt sich jedoch auf alle zuvor geprägten Token aus, es sei denn, Sie speichern pro Token URIs.
F: Was passiert, wenn zwei Token dieselbe ID haben? A: Der Vertrag wird während der Prägung aufgrund doppelter Zuordnungsprüfungen, die durch die _owners -Zuordnungsvalidierung von OpenZeppelin erzwungen werden, zurückgesetzt.
F: Sind die Benzinkosten für ERC-721 höher als für ERC-20? A: Ja – ERC-721-Vorgänge erfordern individuelle Speicherschreibvorgänge pro Token-ID, was zu einem deutlich höheren Gasverbrauch für das Prägen und Übertragen führt.
F: Muss ich Lizenzgebühren in den Vertrag aufnehmen? A: Nein – Lizenzgebühren sind nicht Teil der ERC-721-Spezifikation. Plattformen wie OpenSea lesen Lizenzinformationen aus der Funktion royaltyInfo , wenn sie über ERC-2981 implementiert werden.
Haftungsausschluss:info@kdj.com
Die bereitgestellten Informationen stellen keine Handelsberatung dar. kdj.com übernimmt keine Verantwortung für Investitionen, die auf der Grundlage der in diesem Artikel bereitgestellten Informationen getätigt werden. Kryptowährungen sind sehr volatil und es wird dringend empfohlen, nach gründlicher Recherche mit Vorsicht zu investieren!
Wenn Sie glauben, dass der auf dieser Website verwendete Inhalt Ihr Urheberrecht verletzt, kontaktieren Sie uns bitte umgehend (info@kdj.com) und wir werden ihn umgehend löschen.
-
RAIN Jetzt handeln$0.007852
113.00%
-
PIPPIN Jetzt handeln$0.06097
51.96%
-
PARTI Jetzt handeln$0.1396
42.04%
-
WAVES Jetzt handeln$0.9141
41.69%
-
ARC Jetzt handeln$0.04302
35.73%
-
HONEY Jetzt handeln$0.01029
21.80%
- Coinbase, Wall Street und das Tauziehen um das zukünftige Finanzsystem
- 2026-01-30 19:15:01
- Der „Spiegelei“-Fehler einer 1-Pfund-Münze knackt und eröffnet eine Royal Mint Rare Value Bonanza
- 2026-01-30 19:05:01
- Der Wert seltener Münzfunde der Royal Mint steigt sprunghaft an: Von Spiegeleiern bis zum Atlantischen Lachs
- 2026-01-30 19:10:02
- Das neue Spiel der Wall Street: Warum kluge Investoren Bitcoin immer im Auge behalten, während Bitcoin in seine nächste Ära eintritt
- 2026-01-30 19:05:01
- Kindred Labs führt KI-Begleiter mit KIN-Token-Airdrop und öffentlicher Auflistung ein: Alle Augen auf den Preis
- 2026-01-30 19:10:02
- Coinstore steht vor einer Prüfung, da die Auflistung des Spur-Protokolls inmitten der Unsicherheit über SON-Ansprüche andauert
- 2026-01-30 19:00:02
Verwandtes Wissen
Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?
Jan 18,2026 at 01:19pm
Grundlegendes zur LayerZero-Architektur 1. LayerZero fungiert als leichtes, erlaubnisloses Interoperabilitätsprotokoll, das die Kommunikation zwischen...
Wie implementiert man EIP-712 für die sichere Signaturüberprüfung?
Jan 20,2026 at 10:20pm
EIP-712-Übersicht und Hauptzweck 1. EIP-712 definiert einen Standard für typisiertes strukturiertes Daten-Hashing und Signieren in Ethereum-Anwendunge...
Wie kann ich mich für Airdrops qualifizieren, indem ich mit neuen Verträgen interagiere?
Jan 24,2026 at 09:00pm
Anforderungen an die Vertragsinteraktion verstehen 1. Die meisten Airdrop-Kampagnen erfordern eine direkte Interaktion mit Smart Contracts, die auf un...
Wie überwacht man einen Smart Contract auf Sicherheitswarnungen?
Jan 21,2026 at 07:59am
On-Chain-Überwachungstools 1. Blockchain-Explorer wie Etherscan und Blockscout ermöglichen die Echtzeitprüfung von Vertragsbytecode, Transaktionsproto...
Wie kann ich einen Vertrag für automatisierte Zahlungen abschließen und finanzieren?
Jan 26,2026 at 08:59am
Grundlegendes zur Bereitstellung intelligenter Verträge 1. Entwickler müssen eine kompatible Blockchain-Plattform wie Ethereum, Polygon oder Arbitrum ...
Wie verwende ich OpenZeppelin-Verträge, um sichere dApps zu erstellen?
Jan 18,2026 at 11:19am
Grundlegendes zu den OpenZeppelin-Vertragsgrundlagen 1. OpenZeppelin Contracts ist eine Bibliothek wiederverwendbarer, von der Community geprüfter Sma...
Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?
Jan 18,2026 at 01:19pm
Grundlegendes zur LayerZero-Architektur 1. LayerZero fungiert als leichtes, erlaubnisloses Interoperabilitätsprotokoll, das die Kommunikation zwischen...
Wie implementiert man EIP-712 für die sichere Signaturüberprüfung?
Jan 20,2026 at 10:20pm
EIP-712-Übersicht und Hauptzweck 1. EIP-712 definiert einen Standard für typisiertes strukturiertes Daten-Hashing und Signieren in Ethereum-Anwendunge...
Wie kann ich mich für Airdrops qualifizieren, indem ich mit neuen Verträgen interagiere?
Jan 24,2026 at 09:00pm
Anforderungen an die Vertragsinteraktion verstehen 1. Die meisten Airdrop-Kampagnen erfordern eine direkte Interaktion mit Smart Contracts, die auf un...
Wie überwacht man einen Smart Contract auf Sicherheitswarnungen?
Jan 21,2026 at 07:59am
On-Chain-Überwachungstools 1. Blockchain-Explorer wie Etherscan und Blockscout ermöglichen die Echtzeitprüfung von Vertragsbytecode, Transaktionsproto...
Wie kann ich einen Vertrag für automatisierte Zahlungen abschließen und finanzieren?
Jan 26,2026 at 08:59am
Grundlegendes zur Bereitstellung intelligenter Verträge 1. Entwickler müssen eine kompatible Blockchain-Plattform wie Ethereum, Polygon oder Arbitrum ...
Wie verwende ich OpenZeppelin-Verträge, um sichere dApps zu erstellen?
Jan 18,2026 at 11:19am
Grundlegendes zu den OpenZeppelin-Vertragsgrundlagen 1. OpenZeppelin Contracts ist eine Bibliothek wiederverwendbarer, von der Community geprüfter Sma...
Alle Artikel ansehen














