시가총액: $3.4257T -1.03%
거래량(24시간): $162.4413B -8.00%
공포와 탐욕 지수:

26 - 두려움

  • 시가총액: $3.4257T -1.03%
  • 거래량(24시간): $162.4413B -8.00%
  • 공포와 탐욕 지수:
  • 시가총액: $3.4257T -1.03%
암호화
주제
암호화
소식
cryptostopics
비디오
최고 암호화

언어 선택

언어 선택

통화 선택

암호화
주제
암호화
소식
cryptostopics
비디오

재진입 공격이란 무엇이며 계약에서 이를 어떻게 방지할 수 있나요?

Reentrancy attacks exploit unchecked external calls in smart contracts, allowing attackers to drain funds by re-entering functions before state updates—highlighted by the $60M DAO hack.

2025/11/10 16:20

스마트 계약의 재진입 공격 이해

1. 재진입 공격은 초기 실행이 완료되기 전에 악의적인 계약이 취약한 함수를 반복적으로 호출할 때 발생합니다. 이 재귀적 동작은 외부 호출의 순서와 스마트 계약 내 상태 변경을 활용합니다.

2. 핵심 취약점은 내부 상태를 업데이트하기 전에 자금을 보내거나 외부 호출을 하는 계약에 있습니다. 공격자는 이 창을 활용하여 출금 기능에 다시 들어가 자금을 여러 번 출금할 수 있습니다.

3. 가장 악명 높은 사례 중 하나는 2016년 DAO 해킹으로, 재진입 결함으로 인해 6천만 달러 상당의 이더리움이 유출되었습니다. 공격자는 대체 기능을 사용하여 철회 메커니즘을 반복적으로 호출했습니다.

4. 이러한 공격은 Ether 전송에만 국한되지 않습니다. 적절한 보호 장치가 마련되지 않은 경우 사용자 제어 계약에 대한 외부 호출은 잠재적으로 무기화될 수 있습니다.

5. 재진입은 분산형 애플리케이션, 특히 대규모 사용자 자금을 처리하는 DeFi 프로토콜에서 가장 중요한 보안 위험 중 하나입니다.

재진입을 가능하게 하는 일반적인 패턴

1. '선 호출, 나중에 업데이트' 패턴을 따르는 계약은 본질적으로 취약합니다. 사용자의 잔액을 줄이기 전에 Ether 또는 토큰을 보내면 공격자가 원래 금액을 반영하는 업데이트된 잔액으로 다시 들어갈 수 있습니다.

2. 적절한 검사 없이 call() , delegatecall() 또는 send() 와 같은 하위 수준 호출에 의존하는 함수는 노출을 증가시킵니다. 이러한 방법은 악의적인 논리를 포함할 수 있는 수신자의 대체 또는 수신 기능을 트리거합니다.

3. 풀오버푸시(Pull-over-Push) 결제 모델을 부적절하게 사용하면 위험이 커집니다. 거래 중에 사전에 자금을 보내는 푸시 기반 시스템은 반복적인 악용을 위한 기회를 만듭니다.

4. 여러 인터페이스에 걸친 복잡한 계약 상호 작용으로 인해 위험이 증폭됩니다. 하나의 계약이 다른 계약을 호출하고 둘 다 변경 가능한 상태인 경우 실행 흐름 추적이 어려워지고 감독 가능성이 높아집니다.

5. 상태 업데이트가 원자적이지 않고 외부 상호 작용 후에 발생하는 경우 안전해 보이는 코드라도 손상될 수 있습니다.

효과적인 예방 전략

1. CEI(Checks-Effects-Interactions) 패턴을 엄격하게 적용합니다. 항상 입력의 유효성을 검사하고 내부 상태 변수를 업데이트한 다음 외부 호출을 수행합니다. 이 시퀀스는 재진입 창을 제거합니다.

2. OpenZeppelin의 ReentrancyGuard 와 같은 라이브러리에서 제공하는 뮤텍스 잠금 또는 재진입 가드를 사용하십시오. 이는 이미 실행 중인 함수가 다시 입력되는 것을 방지하는 잠금 메커니즘을 적용합니다.

3. 낮은 수준의 통화 사용을 제한합니다. 종종 재귀 실행을 방지하는 가스비 한도와 같은 보호 기능이 내장된 transfer() 와 같은 높은 수준의 전송 함수를 선호합니다.

4. 직접 지급 대신 인출 패턴을 구현합니다. 사용자가 별도의 기능을 통해 자금 검색을 시작할 수 있도록 하여 민감한 작업 중에 외부 통화 횟수를 최소화합니다.

5. 정기적인 감사 및 정적 분석 도구를 개발 라이프사이클에 통합하여 배포 전에 잠재적인 재진입 벡터를 감지해야 합니다.

자주 묻는 질문

재진입 공격에서 대체 기능의 역할은 무엇입니까? 폴백 기능은 계약이 데이터 없이 Ether를 받으면 자동으로 실행됩니다. 공격자는 취약한 기능을 다시 호출하는 악의적인 폴백을 만들어 원래 거래가 완료되기 전에 자금을 소모하는 루프를 만듭니다.

동일한 계약의 서로 다른 기능 간에 재진입이 발생할 수 있나요? 예. 교차 기능 재진입은 한 기능이 업데이트되지 않은 공유 상태를 활용하여 동일한 계약의 다른 기능으로 다시 연결되는 외부 호출을 할 때 발생합니다. 이러한 경로를 차단하려면 적절한 상태 관리 및 보호가 필수적입니다.

대리 계약은 재진입에 영향을 받지 않나요? 아니요. 논리 구현에 확인되지 않은 외부 호출이 포함된 경우 프록시 계약이 여전히 취약할 수 있습니다. 프록시는 업그레이드 가능한 논리 계약에 대한 호출을 위임하므로 재진입을 포함한 논리 계층의 모든 결함은 여전히 ​​악용될 수 있습니다.

가스 제한은 재진입 시도에 어떤 영향을 미치나요? 일부 초기 방어에서는 재귀를 차단하기 위해 사용 가능한 모든 가스를 소비하는 데 의존했습니다. 그러나 현대의 공격은 정확한 가스 추정을 사용하여 이를 우회합니다. 가스 한도에만 의존하는 것은 신뢰할 수 없습니다. 구조적 코드 패턴은 더 강력한 보호를 제공합니다.

부인 성명:info@kdj.com

제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!

본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.

관련 지식

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

2025-11-10 05:20:08

스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

2025-11-11 05:59:39

블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

2025-11-11 22:40:12

Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

2025-11-13 04:00:32

외부 소유 계정(EOA) 이해 1. 외부 소유 계정은 개인 키로 직접 제어됩니다. 즉, 해당 키 소유자만 계정에서 거래를 시작할 수 있습니다. EOA에는 관련 코드가 없습니다. 이는 블록체인에서 거래를 보내고 받는 데 사용되는 간단한 주소입니다. 이러한 계정은 일반적으...

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

2025-11-13 05:39:54

ERC-2981 NFT 로열티 표준 이해 1. ERC-2981 표준은 대체 불가능한 토큰(NFT)에 대한 로열티 메커니즘을 도입하는 제안된 이더리움 의견 요청입니다. 로열티에 대한 기본 지원이 부족한 ERC-721 및 ERC-1155와 같은 이전 NFT 표준과 달리 E...

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

2025-11-12 11:39:42

최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

2025-11-10 05:20:08

스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

2025-11-11 05:59:39

블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

2025-11-11 22:40:12

Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

2025-11-13 04:00:32

외부 소유 계정(EOA) 이해 1. 외부 소유 계정은 개인 키로 직접 제어됩니다. 즉, 해당 키 소유자만 계정에서 거래를 시작할 수 있습니다. EOA에는 관련 코드가 없습니다. 이는 블록체인에서 거래를 보내고 받는 데 사용되는 간단한 주소입니다. 이러한 계정은 일반적으...

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

2025-11-13 05:39:54

ERC-2981 NFT 로열티 표준 이해 1. ERC-2981 표준은 대체 불가능한 토큰(NFT)에 대한 로열티 메커니즘을 도입하는 제안된 이더리움 의견 요청입니다. 로열티에 대한 기본 지원이 부족한 ERC-721 및 ERC-1155와 같은 이전 NFT 표준과 달리 E...

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

2025-11-12 11:39:42

최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...

모든 기사 보기

User not found or password invalid

Your input is correct