Marktkapitalisierung: $2.8167T -5.61%
Volumen (24h): $179.5196B 61.64%
Angst- und Gier-Index:

28 - Furcht

  • Marktkapitalisierung: $2.8167T -5.61%
  • Volumen (24h): $179.5196B 61.64%
  • Angst- und Gier-Index:
  • Marktkapitalisierung: $2.8167T -5.61%
Kryptos
Themen
Cryptospedia
Nachricht
Cryptostopics
Videos
Top Cryptospedia

Sprache auswählen

Sprache auswählen

Währung wählen

Kryptos
Themen
Cryptospedia
Nachricht
Cryptostopics
Videos

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.

Verwandtes Wissen

Wie führe ich eine kettenübergreifende Nachricht mit einem LayerZero-Vertrag aus?

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?

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?

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?

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?

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?

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?

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?

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?

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?

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?

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?

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

User not found or password invalid

Your input is correct