-
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%
Wiedereintrittsangriffe in Smart Contracts verstehen (Der DAO-Hack erklärt)
A reentrancy attack exploits Ethereum’s execution model by recursively calling a vulnerable function before state updates, as seen in The DAO hack—where $50M was drained due to updating balances after external calls.
Jan 16, 2026 at 01:40 am
Was ist ein Wiedereintrittsangriff?
1. Ein Wiedereintrittsangriff tritt auf, wenn ein externer Vertrag den aktuellen Vertrag zurückruft, bevor die ursprüngliche Ausführung abgeschlossen ist.
2. Diese Schwachstelle entsteht durch unsachgemäße Zustandsverwaltung – insbesondere, wenn Zustandsvariablen nach externen Aufrufen und nicht vorher aktualisiert werden.
3. Der Angreifer setzt einen böswilligen Vertrag ein, der eine Fallback-Funktion enthält, die die anfällige Funktion im Zielvertrag rekursiv aufruft.
4. Jeder rekursive Aufruf gelangt erneut in denselben Logikpfad und verbraucht wiederholt Geld, ohne dass der Kontostand aktualisiert wird, bis der gesamte Aufrufstapel abgewickelt ist.
5. Solche Angriffe nutzen das synchrone Single-Thread-Ausführungsmodell von Ethereum aus, bei dem externe Aufrufe den Kontrollfluss innerhalb des Aufrufkontexts behalten.
Der DAO-Vorfall: Ein historischer Zusammenbruch
1. Das DAO war eine dezentrale autonome Organisation, die 2016 auf Ethereum gegründet wurde und als Risikokapitalfonds konzipiert war, der durch Smart-Contract-Regeln gesteuert wird.
2. Sein Code ermöglichte es Token-Inhabern, sich vom DAO zu trennen und Ether durch Aufrufen einer SplitDAO -Funktion zurückzugewinnen.
3. Diese Funktion übertrug Ether an die Adresse des Anforderers, bevor der interne Kontostand aktualisiert wurde, wodurch ein klassisches Wiedereintrittsfenster entstand.
4. Ein Angreifer hat einen Vertrag mit einer Fallback-Funktion eingesetzt, der bei Erhalt von Geldern erneut SplitDAO auslöste.
5. Über mehrere verschachtelte Anrufe wurden mehr als 3,6 Millionen ETH – damals im Wert von über 50 Millionen US-Dollar – abgeschöpft, bevor die Transaktion rückgängig gemacht oder gestoppt wurde.
Wie das Ausführungsmodell von Ethereum Wiedereintritt ermöglicht
1. Jeder externe Aufruf in Solidity wird im gleichen Transaktionskontext ausgeführt, wodurch Arbeitsspeicher, Speicher und Aufrufstapel-Sichtbarkeit erhalten bleiben.
2. Es gibt keinen automatischen Wiedereintrittsschutz, es sei denn, er wird explizit über Muster wie Checks-Effects-Interactions implementiert.
3. Gasgrenzwerte verhindern keine Rekursion; Sie schränken nur die Gesamtberechnung ein und Fallback-Funktionen erfordern zur Ausführung nur minimalen Aufwand.
4. Die EVM erzwingt keine Isolation zwischen Aufrufer und Angerufenem – vom Angerufenen vorgenommene Zustandsänderungen sind für den Aufrufer während der laufenden Ausführung sichtbar.
5. Entwickler unterschätzen oft, wie stark voneinander abhängige Vertragsinteraktionen sein können, insbesondere wenn es um Token oder Orakel Dritter geht.
Gängige Codemuster, die zum Wiedereintritt einladen
1. Aktualisierung von Guthaben oder Flags nach dem Senden von Ether oder dem Aufruf externer Verträge statt vorher.
2. Verwendung von call.value()() ohne Validierung von Rückgabewerten oder Begrenzung der Rekursionstiefe.
3. Sich bei der Buchhaltung auf this.balance verlassen, anstatt Salden in Speichervariablen zu verfolgen.
4. Implementierung von Auszahlungsmustern ohne Sperren, Mutexe oder Wiedereintrittsmodifikatoren wie ReentrancyGuard von OpenZeppelin.
5. Fehler bei der Prüfung der geerbten Logik – insbesondere bei der Verwendung von Proxy-Mustern oder aktualisierbaren Verträgen, bei denen der Delegatecall den Kontext beibehält.
Häufig gestellte Fragen
F: Kann es bei ERC-20-Transfers zu einem Wiedereintritt kommen? A: Standardmäßige ERC-20-Übertragungsfunktionen lösen keine externen Aufrufe aus, sodass ein nativer Wiedereintritt nicht möglich ist. Allerdings führen Erweiterungen wie transferFrom in Kombination mit Hooks (z. B. in ERC-777) Callback-Oberflächen ein, bei denen ein Wiedereintritt auftreten kann.
F: War der DAO-Hack aufgrund einer Hard Fork umkehrbar? A: Ja. Die Ethereum-Community führte einen Hard Fork durch, um gestohlene Gelder wiederherzustellen, indem sie den Kettenverlauf neu schrieb, was zur Aufspaltung von Ethereum und Ethereum Classic führte.
F: Verhindern moderne Solidity-Versionen standardmäßig den Wiedereintritt? A: Nein. Solidity v0.8.x bietet sicherere Arithmetik und ein sichereres Zurücksetzungsverhalten, führt jedoch keinen automatischen Wiedereintrittsschutz ein. Entwickler müssen weiterhin Abwehrmuster manuell anwenden.
F: Ist die Verwendung von require(msg.sender.call{value: amount}('')) sicherer als address.send() ? A: Beides ist nicht grundsätzlich sicher. Beide ermöglichen Wiedereintritt, wenn sie vor Statusaktualisierungen verwendet werden. Der entscheidende Faktor ist die Reihenfolge der Interaktionen – nicht der spezifische Aufrufmechanismus.
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%
- Blockchains, Krypto-Tokens, Markteinführung: Unternehmenslösungen und echte Versorgungsunternehmen stehlen das Rampenlicht
- 2026-01-31 12:30:02
- Der Delta-Skew von Bitcoin-Optionen steigt sprunghaft an, was auf große Marktangst inmitten der Volatilität hindeutet
- 2026-01-31 13:00:02
- Cardano sichert sich Tier-One-Stablecoin: USDCX kommt inmitten globaler Regulierungsbestrebungen
- 2026-01-31 13:00:02
- Eine glänzende Hommage: Oneida Woman, Washingtons Armee und die neue 1-Dollar-Münze
- 2026-01-31 12:55:01
- Super Bowl LX: Coin-Wurf-Trends deuten trotz des jüngsten Anstiegs der Heads auf Zahl hin
- 2026-01-31 07:30:02
- Antiker Fund eines australischen Goldgräbers: Japanische Relikte tauchen auf und schreiben die Goldrausch-Geschichte neu
- 2026-01-31 07:20:01
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














