-
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 in Solidity occurs when an external call allows a malicious contract to recursively execute the same function, potentially draining funds or corrupting state.
2025/07/20 08:49
견고성의 재 신장 이해
Reentrancy는 내부 상태 변경을 완료하기 전에 함수가 신뢰할 수없는 계약을 외부 호출 할 때 발생하는 Soldy Smart 계약 의 중요한 보안 취약점입니다. 이를 통해 외부 계약은 원래 기능으로 재귀 적으로 다시 전화하여 자금을 배수하거나 계약의 논리를 손상시킬 수 있습니다.
2016 년 악명 높은 DAO 해킹은 재창조를 어떻게 이용할 수 있는지에 대한 대표적인 예였습니다. 공격자는 악의적 인 폴백 기능을 사용하여 계약이 잔액을 업데이트하기 전에 철수를 반복적으로 트리거하여 수백만의 에테르가 손실되었습니다.
이러한 취약점을 방지하기 위해 개발자는 외부 통화를 확보 하고 외부 상호 작용 전에 상태 변경이 발생하는 모범 사례 및 설계 패턴을 구현해야합니다.
점검 효과 상호 작용 패턴을 사용하십시오
재창조를 방지하는 가장 효과적인 방법 중 하나는 점검 효과 상호 작용 패턴을 따르는 것입니다. 이 패턴은 외부 통화가 실행되기 전에 모든 내부 상태 변경이 이루어 지도록합니다.
- 점검 : 입력 및 조건을 확인하십시오.
- 효과 : 계약의 상태 변수를 업데이트하십시오.
- 상호 작용 : 외부 계약을 호출하거나 에테르를 보내십시오.
이 순서를 준수함으로써, 재창조 시도가 발생하더라도 내부 상태가 이미 업데이트되어 이중 지출 또는 무단 잔액 액세스를 방지해야합니다.
예를 들어 간단한 철수 기능을 고려하십시오.
function withdraw(uint amount) public {require(balances[msg.sender] >= amount); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success);
}
이 경우 잔액은 외부 호출 전에 업데이트되어 재창조로부터 안전 합니다.
Mutex 잠금을 구현하십시오
재창조를 방지하는 또 다른 효과적인 방법은 뮤 테스 잠금 장치를 사용하는 것입니다. 이는 실행 중 재창조를 방지하는 상태 변수입니다.
간단한 예는 부울 플래그를 사용하여 재입고를 차단하는 것입니다.
bool private locked;기능 철수 (uint 금액) public {require(!locked); locked = true; require(balances[msg.sender] >= amount); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success); locked = false;}
이렇게하면 기능이 여전히 실행되는 동안 기능을 다시 입력 할 수 없으며 재귀 호출을 효과적으로 차단합니다. 그러나 개발자는 뮤텍스를 사용할 때 교착 상태 나 예기치 않은 동작을 만들지 않도록주의해야합니다.
OpenZeppelin의 ReentrancyGuard를 사용하십시오
개발자는 MUTEX 로직을 수동으로 구현하는 대신 OpenZeppelin 이 제공하는 ReentrancyGuard 계약을 사용하여 안전하고 테스트 된 솔루션을 제공 할 수 있습니다.
ReentrancyGuard를 사용하려면 :
- 계약 가져 오기 :
import '@openzeppelin/contracts/security/ReentrancyGuard.sol'; - 계약에서 상속 :
contract MyContract is ReentrancyGuard - 재생성에 취약한 기능에
nonReentrant수정자를 적용하십시오.
pragma solidity ^0.8.0;import '@OpenZeppelin/contracts/security/reentrancyguard.sol';계약 SecureWithDrawal은 ReentrancyGuard {
mapping(address => uint) public balances; function deposit() external payable { balances[msg.sender] += msg.value; } function withdraw(uint amount) external nonReentrant { require(balances[msg.sender] >= amount, 'Insufficient balance'); balances[msg.sender] -= amount; (bool success, ) = msg.sender.call{value: amount}(''); require(success, 'Transfer failed'); }}
이 접근법은 Mutex 처리의 복잡성을 추상화하고 버그를 도입 할 위험을 줄여서 많은 개발자에게 선호되는 방법입니다.
원시 통화를 피하고 안전하게 전송을 사용하십시오
Solidity에서 address.call{value: ...}('') 는 transfer() 또는 send() 보다 유연하지만 가스 제한을 제거하여 Reentrancy에 취약합니다.
-
transfer()및send()가 2300 가스 만 앞으로 전달하여 의미있는 실행에 불충분하므로 재창조를 방지합니다 . - 그러나
call()는 사용 가능한 모든 가스를 전달하여 공격자가 폴백 중에 복잡한 악성 논리를 실행하거나 기능을 수신 할 수 있습니다.
이것을 완화하기 위해 :
- 간단한 에테르 전송에 대해
transfer()또는send()선호합니다. -
call()사용하는 경우 전화가 발생하기 전에 상태 변경이 발생하고 재창조 경비원이 마련되어 있는지 확인하십시오.
FAQ : 자주 묻는 질문
Q : 견고성에 대한 재창조 공격은 무엇입니까? A : 재창조 공격은 외부 계약이 실행을 완료하기 전에 통화 함수로 다시 전화를 걸 때 발생하며, 종종 승인되지 않은 자금 철회 또는 주 부패 로 이어집니다.
Q : OpenZeppelin의 ReentrancyGuard를 사용하지 않고 재창조를 방지 할 수 있습니까? A : 그렇습니다. 체크 효과-인터 링크 패턴을 수동으로 구현하거나 함수 실행 중에 재창조를 차단하기 위해 뮤트 잠금 장치를 사용하여.
Q : 현대식 견고성 버전에서 address.transfer ()를 사용하는 것이 안전합니까? A : transfer() 가 가스를 제한하고 재창조를 방지하는 동안 수신자 계약이 가스가 부족한 경우 예기치 않게 실패 할 수 있습니다. 간단한 전송에 대한 call() 보다 여전히 안전한 것으로 간주됩니다.
Q : Solidity의 모든 외부 통화가 Reentrancy에 취약합니까? A : 전부는 아니지만 사용자 제어 계약 에 대한 외부 호출은 잠재적 벡터가 될 수 있습니다. 상태 변경이 통화 자체가 아니라 외부 통화를 따를 때 취약성이 발생합니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 제도적 지원 환경 변화 속에서 비트코인 유동성 테스트에 직면
- 2026-02-05 13:05:01
- 폭스바겐 타이론 R-라인 7인승: 럭셔리 패밀리 SUV의 새로운 시대가 인도를 강타합니다
- 2026-02-05 13:00:01
- AI, 암호화폐 현상금 및 인간 노동: 변화하는 업무 환경
- 2026-02-05 13:00:01
- 폭스바겐, 타이론 R-라인 출시: 플래그십 7인승 SUV 사전 예약 시작
- 2026-02-05 12:55:01
- 분석가의 경고와 시장 심리 변화 속에서 비트코인 하락
- 2026-02-05 09:40:02
- Great Stablecoin 대결: 시스템적 위험, GENIUS 법, 월스트리트의 미래를 위한 전투
- 2026-02-05 12:55:01
관련 지식
선물에서 감정과 "복수 거래"를 관리하는 방법은 무엇입니까?
2026-02-05 00:19:32
선물시장의 감정적 요인 이해 1. 시장 변동성은 심리적 상태에 직접적인 영향을 미치며, 종종 급격한 가격 변동에 따른 두려움이나 도취감을 증폭시킵니다. 2. 손실은 뇌의 위협 대응 시스템을 활성화시켜 체계적인 분석보다는 충동적인 결정으로 이어집니다. 3. 소셜 미디어 ...
공포탐욕 지수를 사용하여 시장 심리를 분석하는 방법은 무엇입니까?
2026-02-05 07:40:21
공포와 탐욕 지수 이해하기 1. 공포와 탐욕 지수는 암호화폐 투자자들 사이에 만연한 감정 상태를 정량화하기 위해 고안된 복합 지표입니다. 변동성, 시장 모멘텀, 소셜 미디어 활동, 설문조사 결과, Bitcoin 지배력, 검색 동향 등 다양한 소스의 데이터를 집계합니다....
거래량 프로필을 사용하여 주요 선물 진입 수준을 찾는 방법은 무엇입니까?
2026-02-04 23:39:35
볼륨 프로필 구조 이해 1. 거래량 프로필은 정의된 기간 동안 특정 가격 수준의 거래량 분포를 차트에 수평 히스토그램으로 표시합니다. 2. 통제점(POC)은 거래량 집중도가 가장 높은 가격 수준을 나타내며 종종 가격 반전을 위한 자석 역할을 합니다. 3. VAH(Val...
100배 레버리지로 Bitcoin 선물을 거래하는 방법은 무엇입니까? (고위험 설정)
2026-02-05 11:00:08
Bitcoin 선물 메커니즘 이해 1. Bitcoin 선물 계약은 규제 대상 또는 역외 파생상품 거래소에서 거래되는 BTC를 미래의 미리 정해진 가격과 날짜에 매수 또는 매도하는 계약을 나타냅니다. 2. 현물 거래와 달리 선물은 거래자가 매수 및 매도 포지션을 통해 가...
교차 마진 거래를 사용하여 자본 효율성을 극대화하는 방법은 무엇입니까?
2026-02-05 00:40:24
교차 마진 거래 기초 1. 교차 마진 거래를 통해 거래자는 전체 계좌 잔고를 여러 시장의 오픈 포지션에 대한 담보로 동시에 사용할 수 있습니다. 2. 각 포지션에 전용 마진 풀이 있는 격리 마진과 달리 교차 마진은 지갑에 보관된 모든 자산의 자산을 동적으로 할당합니다....
주요 뉴스 이벤트 중에 암호화폐 계약을 거래하는 방법은 무엇입니까? (물가지수/FOMC)
2026-02-05 09:59:37
거시적 데이터 공개에 대한 시장 민감도 이해 1. 암호화폐 선물 시장은 통화 정책 기대와 직접적인 연관이 있기 때문에 미국 CPI 및 FOMC 발표 중에 뚜렷한 변동성을 보입니다. 2. Bitcoin 및 이더리움 무기한 계약은 예상 포지셔닝을 반영하여 공식 데이터가 공...
선물에서 감정과 "복수 거래"를 관리하는 방법은 무엇입니까?
2026-02-05 00:19:32
선물시장의 감정적 요인 이해 1. 시장 변동성은 심리적 상태에 직접적인 영향을 미치며, 종종 급격한 가격 변동에 따른 두려움이나 도취감을 증폭시킵니다. 2. 손실은 뇌의 위협 대응 시스템을 활성화시켜 체계적인 분석보다는 충동적인 결정으로 이어집니다. 3. 소셜 미디어 ...
공포탐욕 지수를 사용하여 시장 심리를 분석하는 방법은 무엇입니까?
2026-02-05 07:40:21
공포와 탐욕 지수 이해하기 1. 공포와 탐욕 지수는 암호화폐 투자자들 사이에 만연한 감정 상태를 정량화하기 위해 고안된 복합 지표입니다. 변동성, 시장 모멘텀, 소셜 미디어 활동, 설문조사 결과, Bitcoin 지배력, 검색 동향 등 다양한 소스의 데이터를 집계합니다....
거래량 프로필을 사용하여 주요 선물 진입 수준을 찾는 방법은 무엇입니까?
2026-02-04 23:39:35
볼륨 프로필 구조 이해 1. 거래량 프로필은 정의된 기간 동안 특정 가격 수준의 거래량 분포를 차트에 수평 히스토그램으로 표시합니다. 2. 통제점(POC)은 거래량 집중도가 가장 높은 가격 수준을 나타내며 종종 가격 반전을 위한 자석 역할을 합니다. 3. VAH(Val...
100배 레버리지로 Bitcoin 선물을 거래하는 방법은 무엇입니까? (고위험 설정)
2026-02-05 11:00:08
Bitcoin 선물 메커니즘 이해 1. Bitcoin 선물 계약은 규제 대상 또는 역외 파생상품 거래소에서 거래되는 BTC를 미래의 미리 정해진 가격과 날짜에 매수 또는 매도하는 계약을 나타냅니다. 2. 현물 거래와 달리 선물은 거래자가 매수 및 매도 포지션을 통해 가...
교차 마진 거래를 사용하여 자본 효율성을 극대화하는 방법은 무엇입니까?
2026-02-05 00:40:24
교차 마진 거래 기초 1. 교차 마진 거래를 통해 거래자는 전체 계좌 잔고를 여러 시장의 오픈 포지션에 대한 담보로 동시에 사용할 수 있습니다. 2. 각 포지션에 전용 마진 풀이 있는 격리 마진과 달리 교차 마진은 지갑에 보관된 모든 자산의 자산을 동적으로 할당합니다....
주요 뉴스 이벤트 중에 암호화폐 계약을 거래하는 방법은 무엇입니까? (물가지수/FOMC)
2026-02-05 09:59:37
거시적 데이터 공개에 대한 시장 민감도 이해 1. 암호화폐 선물 시장은 통화 정책 기대와 직접적인 연관이 있기 때문에 미국 CPI 및 FOMC 발표 중에 뚜렷한 변동성을 보입니다. 2. Bitcoin 및 이더리움 무기한 계약은 예상 포지셔닝을 반영하여 공식 데이터가 공...
모든 기사 보기














