-
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%
스마트 계약의 재진입 공격 이해(DAO 해킹 설명)
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.
2026/01/16 01:40
재진입 공격이란 무엇입니까?
1. 재진입 공격은 초기 실행이 완료되기 전에 외부 계약이 현재 계약을 다시 호출할 때 발생합니다.
2. 이 취약점은 부적절한 상태 관리, 특히 상태 변수가 외부 호출 이전이 아닌 이후에 업데이트되는 경우 발생합니다.
3. 공격자는 대상 계약의 취약한 기능을 반복적으로 호출하는 폴백 기능이 포함된 악성 계약을 배포합니다.
4. 각 재귀 호출은 동일한 논리 경로에 다시 들어가 전체 호출 스택이 해제될 때까지 잔액이 업데이트되지 않고 반복적으로 자금을 소모합니다.
5. 이러한 공격은 외부 호출이 호출 컨텍스트 내에서 제어 흐름을 유지하는 Ethereum의 동기식 단일 스레드 실행 모델을 악용합니다.
DAO 사건: 역사적 붕괴
1. DAO는 2016년 이더리움에서 시작된 분산형 자율 조직으로, 스마트 계약 규칙에 따라 관리되는 벤처 캐피탈 펀드로 설계되었습니다.
2. 해당 코드를 사용하면 토큰 보유자가 DAO에서 분할하고 SplitDAO 함수를 호출하여 이더리움을 회수할 수 있습니다.
3. 해당 기능은 내부 잔액을 업데이트하기 전에 요청자의 주소로 이더를 전송하여 전형적인 재진입 창을 생성했습니다.
4. 공격자는 자금을 받으면 SplitDAO를 다시 트리거하는 폴백 기능이 포함된 계약을 배포했습니다.
5. 여러 번의 중첩 호출을 통해 거래가 되돌리거나 중단되기 전에 당시 5천만 달러 이상의 가치가 있는 360만 개 이상의 ETH가 빠져나갔습니다.
Ethereum의 실행 모델이 재진입을 활성화하는 방법
1. Solidity의 모든 외부 호출은 동일한 트랜잭션 컨텍스트에서 실행되어 메모리, 저장소 및 호출 스택 가시성을 유지합니다.
2. Checks-Effects-Interactions와 같은 패턴을 통해 명시적으로 구현되지 않는 한 자동 재진입 보호 기능은 없습니다.
3. 가스 제한은 재발을 방지하지 않습니다. 전체 계산만 제한하며 대체 기능은 실행하는 데 최소한의 가스만 필요합니다.
4. EVM은 호출자와 호출 수신자 간의 격리를 강제하지 않습니다. 호출 수신자가 변경한 상태는 실행이 진행되는 동안 호출자에게 표시됩니다.
5. 개발자들은 특히 제3자 토큰이나 오라클이 포함될 때 상호의존적인 계약 상호작용이 얼마나 깊게 이루어질 수 있는지를 과소평가하는 경우가 많습니다.
재진입을 유도하는 공통 코드 패턴
1. 이전 대신 이더를 보내거나 외부 계약을 호출한 후 잔액이나 플래그를 업데이트합니다.
2. 반환 값의 유효성을 검사하거나 재귀 깊이를 제한하지 않고 call.value()()를 사용합니다.
3. 저장 변수의 잔액을 추적하는 대신 회계에 this.balance를 사용합니다.
4. OpenZeppelin의 ReentrancyGuard 와 같은 잠금, 뮤텍스 또는 재진입 수정자 없이 철회 패턴을 구현합니다.
5. 상속된 논리를 감사하지 못합니다. 특히 위임자 호출이 컨텍스트를 유지하는 프록시 패턴이나 업그레이드 가능한 계약을 사용할 때 더욱 그렇습니다.
자주 묻는 질문
Q: ERC-20 전송에서 재진입이 발생할 수 있나요? A: 표준 ERC-20 전송 함수는 외부 호출을 트리거하지 않으므로 기본 재진입이 불가능합니다. 그러나 후크(예: ERC-777)와 결합된 transferFrom 과 같은 확장은 재진입이 발생할 수 있는 콜백 표면을 도입합니다.
Q: DAO 해킹은 하드포크 때문에 되돌릴 수 있었나요? 답: 그렇습니다. 이더리움 커뮤니티는 체인 기록을 다시 작성하여 도난당한 자금을 복원하기 위해 하드포크를 실행했으며 그 결과 이더리움과 이더리움 클래식이 분리되었습니다.
Q: 최신 Solidity 버전은 기본적으로 재진입을 방지합니까? A: 아니요. Solidity v0.8.x에는 더 안전한 산술 및 되돌리기 동작이 포함되어 있지만 재진입 보호 기능을 자동으로 주입하지는 않습니다. 개발자는 여전히 방어 패턴을 수동으로 적용해야 합니다.
Q: require(msg.sender.call{value: amount}('')) 를 사용하는 것이 address.send() 보다 안전한가요? A: 둘 다 본질적으로 안전하지는 않습니다. 둘 다 상태 업데이트 전에 사용되는 경우 재진입을 허용합니다. 중요한 요소는 특정 통화 메커니즘이 아니라 상호 작용 순서입니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 슈퍼볼 LX: 최근 헤드(Heads)의 급증에도 불구하고 동전 던지기 추세는 뒤처져 있습니다.
- 2026-01-31 07:30:02
- 호주 탐사자의 고대 발견: 일본 유물 표면, 골드러시 전설 재작성
- 2026-01-31 07:20:01
- 미국 조폐국, 주화 가격 조정: 클래드 컬렉터 세트 특별 기념일 출시로 대폭 인상
- 2026-01-31 07:20:01
- THORChain, 비트코인 DEX 정의에 대해 CoinGecko와 격렬한 논쟁을 촉발: 진정한 분산화를 위한 전투
- 2026-01-31 07:15:01
- 판타지 풋볼 프렌지: Premier League Round 24의 주요 추천 및 조언
- 2026-01-31 06:40:02
- 시장 변동성 속에서 2026년 암호화폐 급락 가능성에 대비
- 2026-01-31 07:15:01
관련 지식
LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?
2026-01-18 13:19:39
LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...
안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?
2026-01-20 22:20:26
EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...
새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?
2026-01-24 21:00:23
계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...
보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?
2026-01-21 07:59:57
온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...
자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?
2026-01-26 08:59:35
스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...
OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?
2026-01-18 11:19:49
OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?
2026-01-18 13:19:39
LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...
안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?
2026-01-20 22:20:26
EIP-712 개요 및 핵심 목적 1. EIP-712는 이더리움 애플리케이션에서 형식화된 구조화된 데이터 해싱 및 서명에 대한 표준을 정의합니다. 2. 서명 요청 시 원시 16진수 문자열 대신 사람이 읽을 수 있는 도메인 및 메시지 필드를 지갑에 표시할 수 있습니다. ...
새로운 계약과 상호 작용하여 에어드랍 자격을 얻는 방법은 무엇입니까?
2026-01-24 21:00:23
계약 상호 작용 요구 사항 이해 1. 대부분의 에어드롭 캠페인은 Ethereum, Arbitrum 또는 Base와 같은 지원되는 블록체인에 배포된 스마트 계약과의 직접적인 상호 작용을 요구합니다. 2. 상호 작용에는 일반적으로 dApp 인터페이스에 연결된 지갑을 사용하...
보안 경고에 대한 스마트 계약을 모니터링하는 방법은 무엇입니까?
2026-01-21 07:59:57
온체인 모니터링 도구 1. Etherscan 및 Blockscout와 같은 블록체인 탐색기를 사용하면 계약 바이트 코드, 트랜잭션 로그 및 내부 호출을 실시간으로 검사할 수 있습니다. 2. 온체인 데이터를 신뢰하기 전에 계약 확인 상태를 확인해야 합니다. 확인되지 않은...
자동 결제 계약을 설정하고 자금을 조달하는 방법은 무엇입니까?
2026-01-26 08:59:35
스마트 계약 배포 이해 1. 개발자는 가스 효율성 및 보안 요구 사항을 기반으로 Ethereum, Polygon 또는 Arbitrum과 같은 호환 가능한 블록체인 플랫폼을 선택해야 합니다. 2. Solidity는 특히 반복 또는 조건부 이체를 위한 결제 자동화 로직 작...
OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?
2026-01-18 11:19:49
OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...
모든 기사 보기














