-
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%
재진입 공격이란 무엇이며 계약에서 이를 어떻게 방지할 수 있나요?
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)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 비트코인의 험난한 길: 인플레이션 급증, 금리 인하 희망이 사라지고 디지털 금 논쟁이 뜨거워지고 있습니다.
- 2026-02-01 09:40:02
- 비트코인은 더 저렴한 데이터 신호를 보여주고, 분석가들은 금 회전을 주목하고 있습니다.
- 2026-02-01 07:40:02
- 비트코인의 최근 하락: 이것이 암호화폐에 대한 궁극적인 '딥 매수' 신호입니까?
- 2026-02-01 07:35:01
- Big Apple Crypto Blues: 거시경제적 소용돌이 속에서 5000억 달러 가치가 사라지면서 비트코인과 이더리움이 휘청거립니다.
- 2026-02-01 07:35:01
- Michael Wrubel, 차세대 대규모 사전 판매로 IPO Genie 선정: 초기 단계 투자를 위한 새로운 시대가 블록체인을 강타
- 2026-02-01 07:30:02
- XRP, 리플, 지원 수준: 암호화폐 변동성의 도시 정글 탐색
- 2026-02-01 06:35:01
관련 지식
현재 유동성 급증 중에 DeFi 계약을 거래하는 방법은 무엇입니까?
2026-02-01 07:00:25
DeFi 프로토콜의 유동성 역학 이해 1. DeFi의 유동성 급증은 종종 이자 농사 인센티브, 토큰 배출 및 크로스체인 연결 활동으로 인한 조정된 자본 유입에 의해 촉발됩니다. 2. 대규모 유동성 풀이 증가된 주문 흐름을 흡수하여 단기 차익거래 창구가 생성되면 자동화된...
암호화폐 계약 가격 검색을 위해 볼륨 프로필을 사용하는 방법은 무엇입니까?
2026-02-01 09:39:59
볼륨 프로필 기본 사항 이해 1. 거래량 프로필은 정의된 기간 동안 특정 가격 수준에서의 거래 활동을 시각적으로 표현한 것으로, 차트의 각 가격대에서 거래된 거래량을 표시합니다. 2. 암호화폐 계약 시장에서는 특히 대량 노드(HVN)와 소량 노드(LVN)를 중심으로 기...
Bybit에서 처음으로 암호화폐 계약을 거래하는 방법은 무엇인가요?
2026-02-01 04:00:10
Bybit 계정 설정 1. Bybit 공식 홈페이지에 접속하여 홈페이지 우측 상단의 '회원가입' 버튼을 클릭하세요. 2. 유효한 이메일 주소를 입력하고 대문자, 소문자, 숫자, 특수문자를 포함하는 강력한 비밀번호를 만드세요. 3. CAPTCHA 인증을 완...
슬리피지가 낮고 레버리지가 높은 암호화폐 계약을 찾는 방법은 무엇입니까?
2026-02-01 04:19:41
활용도가 높은 암호화폐 계약 찾기 1. 거래자들은 종종 분산형 및 중앙형 거래소에서 50배 이상의 레버리지를 제공하는 영구 선물 계약을 검색합니다. Binance, Bybit 및 OKX는 격리 마진 모드에서 최대 125배의 레버리지로 여러 BTC, ETH 및 SOL 쌍...
암호화폐 계약 거래에 대한 미결제약정을 분석하는 방법은 무엇입니까? (프로 전략)
2026-02-01 06:20:01
미결제약정 기본 사항 이해 1. 미결제약정은 선물이나 무기한 스왑 등 미결제 또는 마감되지 않은 미결제 파생 계약의 총 수를 나타냅니다. 2. 특정 기간 동안의 활동을 측정하는 거래량과 달리 미결제약정은 특정 순간에 모든 시장 참가자의 누적 포지션 노출을 반영합니다. ...
암호화폐 계약 계산기를 사용하여 PNL을 추정하는 방법은 무엇입니까?
2026-02-01 09:20:13
암호화폐 계약 계산기 이해 1. 암호화폐 계약 계산기는 실행 전 선물 또는 무기한 스왑 포지션의 잠재적 손익을 계산하도록 설계된 도구입니다. 2. 진입 가격, 청산 가격, 포지션 규모, 레버리지, 계약 유형(선형 또는 역)과 같은 입력이 필요합니다. 3. 계산기는 거래...
현재 유동성 급증 중에 DeFi 계약을 거래하는 방법은 무엇입니까?
2026-02-01 07:00:25
DeFi 프로토콜의 유동성 역학 이해 1. DeFi의 유동성 급증은 종종 이자 농사 인센티브, 토큰 배출 및 크로스체인 연결 활동으로 인한 조정된 자본 유입에 의해 촉발됩니다. 2. 대규모 유동성 풀이 증가된 주문 흐름을 흡수하여 단기 차익거래 창구가 생성되면 자동화된...
암호화폐 계약 가격 검색을 위해 볼륨 프로필을 사용하는 방법은 무엇입니까?
2026-02-01 09:39:59
볼륨 프로필 기본 사항 이해 1. 거래량 프로필은 정의된 기간 동안 특정 가격 수준에서의 거래 활동을 시각적으로 표현한 것으로, 차트의 각 가격대에서 거래된 거래량을 표시합니다. 2. 암호화폐 계약 시장에서는 특히 대량 노드(HVN)와 소량 노드(LVN)를 중심으로 기...
Bybit에서 처음으로 암호화폐 계약을 거래하는 방법은 무엇인가요?
2026-02-01 04:00:10
Bybit 계정 설정 1. Bybit 공식 홈페이지에 접속하여 홈페이지 우측 상단의 '회원가입' 버튼을 클릭하세요. 2. 유효한 이메일 주소를 입력하고 대문자, 소문자, 숫자, 특수문자를 포함하는 강력한 비밀번호를 만드세요. 3. CAPTCHA 인증을 완...
슬리피지가 낮고 레버리지가 높은 암호화폐 계약을 찾는 방법은 무엇입니까?
2026-02-01 04:19:41
활용도가 높은 암호화폐 계약 찾기 1. 거래자들은 종종 분산형 및 중앙형 거래소에서 50배 이상의 레버리지를 제공하는 영구 선물 계약을 검색합니다. Binance, Bybit 및 OKX는 격리 마진 모드에서 최대 125배의 레버리지로 여러 BTC, ETH 및 SOL 쌍...
암호화폐 계약 거래에 대한 미결제약정을 분석하는 방법은 무엇입니까? (프로 전략)
2026-02-01 06:20:01
미결제약정 기본 사항 이해 1. 미결제약정은 선물이나 무기한 스왑 등 미결제 또는 마감되지 않은 미결제 파생 계약의 총 수를 나타냅니다. 2. 특정 기간 동안의 활동을 측정하는 거래량과 달리 미결제약정은 특정 순간에 모든 시장 참가자의 누적 포지션 노출을 반영합니다. ...
암호화폐 계약 계산기를 사용하여 PNL을 추정하는 방법은 무엇입니까?
2026-02-01 09:20:13
암호화폐 계약 계산기 이해 1. 암호화폐 계약 계산기는 실행 전 선물 또는 무기한 스왑 포지션의 잠재적 손익을 계산하도록 설계된 도구입니다. 2. 진입 가격, 청산 가격, 포지션 규모, 레버리지, 계약 유형(선형 또는 역)과 같은 입력이 필요합니다. 3. 계산기는 거래...
모든 기사 보기














