-
Bitcoin
$117700
-0.79% -
Ethereum
$3765
-1.23% -
XRP
$3.577
1.44% -
Tether USDt
$1.000
0.01% -
BNB
$765.0
1.27% -
Solana
$194.9
6.81% -
USDC
$0.9998
0.00% -
Dogecoin
$0.2809
5.95% -
Cardano
$0.8960
2.62% -
TRON
$0.3141
-1.64% -
Hyperliquid
$46.07
-2.31% -
Stellar
$0.4738
-0.36% -
Sui
$3.986
-0.19% -
Chainlink
$19.46
-1.12% -
Hedera
$0.2777
-0.38% -
Avalanche
$25.49
0.62% -
Bitcoin Cash
$523.7
-4.97% -
Shiba Inu
$0.00001554
0.31% -
Litecoin
$116.3
-1.08% -
UNUS SED LEO
$8.981
-0.02% -
Toncoin
$3.292
-0.51% -
Polkadot
$4.502
-1.60% -
Uniswap
$10.85
0.00% -
Ethena USDe
$1.001
0.00% -
Monero
$320.9
-2.19% -
Pepe
$0.00001396
-3.20% -
Bitget Token
$4.926
-2.02% -
Dai
$0.9999
0.00% -
Aave
$321.7
-3.70% -
Bittensor
$432.2
0.02%
견고성의 재창조를 방지하는 방법은 무엇입니까?
외부 통화가 악성 계약이 동일한 기능을 재귀 적으로 실행하여 자금을 배출하거나 부패한 상태를 재귀 적으로 실행할 수있게하는 경우 견고성에 대한 재창조가 발생합니다.
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)로 연락주시면 즉시 삭제하도록 하겠습니다.
- 비트 코인, 트럼프 미디어 및 인수 : 뉴욕 관점
- 2025-07-22 06:30:12
- Venture Capital, Crypto Treasuries 및 Ethena (ENA) : 뉴욕 관점
- 2025-07-22 06:50:13
- SOLANA : 블록 어셈블리 마켓 플레이스가있는 분산 된 나스닥 구축?
- 2025-07-22 06:30:12
- Jito, Bam 및 Solana Mev : 블록 스페이스의 새로운 시대?
- 2025-07-22 06:50:13
- Raydium, Crypto Payroll 및 Transformation : Fintech의 새로운 시대
- 2025-07-22 07:30:12
- 북극 파블로 코인 프리 세일 : 2025 년의 밈 동전 기회?
- 2025-07-22 07:35:12
관련 지식

제작자 대 테이커 요금이란 무엇입니까?
2025-07-19 01:14:23
cryptocurrency 교환 수수료의 기본 사항 이해 cryptocurrency 거래의 세계에서, Maker vs Taker 수수료는 모든 거래자가 이해해야하는 기본 개념입니다. 이 수수료는 주문 유형에 따라 사용자와의 교환으로 청구됩니다. 제작자와 테이커 수수료 ...

암호화 선물 거래 계좌를 확보하는 방법은 무엇입니까?
2025-07-21 23:42:26
암호화 선물 거래의 위험 이해 암호화 선물 거래는 시장 변동성과 레버리지로 인한 상당한 위험을 수반합니다. 거래 계정은 신중하게 관리되지 않으면 해킹, 피싱 또는 마진 청산에 노출 될 수 있습니다 . 이러한 위험을 이해하는 것은 자산을 확보하기위한 첫 번째 단계입니다....

Bitcoin 미래 거래가 사기입니까?
2025-07-22 01:42:18
Bitcoin 선물 거래 이해 Bitcoin 선물 거래는 미래의 미래 가격에서 자신의 가치를 도출하는 계약을 구매 및 판매하는 과정을 말합니다. 이 계약을 통해 거래자는 실제로 기본 자산을 소유하지 않고 Bitcoin의 가격 이동을 추측 할 수 있습니다. 이 개념 자체...

CME의 미래 데이터를 분석하는 방법은 무엇입니까?
2025-07-19 17:22:11
CME의 미래 이해 Bitcoin Bitcoin CME 그룹 (Chicago Mercantile Exchange) 의 미래는 규제 금융 상품을 대표하여 투자자가 기본 자산을 소유하지 않고 Bitcoin의 미래 가격을 추측 할 수있게합니다. 이러한 선물 계약은 중앙 대상...

Bitcoin 계약의 고급 주문 유형
2025-07-21 13:14:41
Bitcoin 계약의 고급 주문 유형 이해 Bitcoin 선물 거래 세계에서 고급 주문 유형은 위험 관리, 전략 자동화 및 실행 효율성 향상에 중요한 역할을합니다. 이러한 주문 유형은 기본 시장을 넘어서서 주문을 제한하며 거래자는 직책에 입력하거나 종료하기위한 조건부 ...

암호화 선물 거래에서 일반적인 실수
2025-07-20 21:56:36
위험 관리없이 과도하게 보입니다 암호화 선물 거래에서 가장 일반적인 실수 중 하나는 과도하게 진행 됩니다. 거래자들은 종종 높은 레버리지를 사용하면 이익을 크게 증가시킬 것이라고 생각하지만, 이는 또한 상당한 손실의 위험을 증가시킵니다. 중단 손실 주문을 설정하지 못하...

제작자 대 테이커 요금이란 무엇입니까?
2025-07-19 01:14:23
cryptocurrency 교환 수수료의 기본 사항 이해 cryptocurrency 거래의 세계에서, Maker vs Taker 수수료는 모든 거래자가 이해해야하는 기본 개념입니다. 이 수수료는 주문 유형에 따라 사용자와의 교환으로 청구됩니다. 제작자와 테이커 수수료 ...

암호화 선물 거래 계좌를 확보하는 방법은 무엇입니까?
2025-07-21 23:42:26
암호화 선물 거래의 위험 이해 암호화 선물 거래는 시장 변동성과 레버리지로 인한 상당한 위험을 수반합니다. 거래 계정은 신중하게 관리되지 않으면 해킹, 피싱 또는 마진 청산에 노출 될 수 있습니다 . 이러한 위험을 이해하는 것은 자산을 확보하기위한 첫 번째 단계입니다....

Bitcoin 미래 거래가 사기입니까?
2025-07-22 01:42:18
Bitcoin 선물 거래 이해 Bitcoin 선물 거래는 미래의 미래 가격에서 자신의 가치를 도출하는 계약을 구매 및 판매하는 과정을 말합니다. 이 계약을 통해 거래자는 실제로 기본 자산을 소유하지 않고 Bitcoin의 가격 이동을 추측 할 수 있습니다. 이 개념 자체...

CME의 미래 데이터를 분석하는 방법은 무엇입니까?
2025-07-19 17:22:11
CME의 미래 이해 Bitcoin Bitcoin CME 그룹 (Chicago Mercantile Exchange) 의 미래는 규제 금융 상품을 대표하여 투자자가 기본 자산을 소유하지 않고 Bitcoin의 미래 가격을 추측 할 수있게합니다. 이러한 선물 계약은 중앙 대상...

Bitcoin 계약의 고급 주문 유형
2025-07-21 13:14:41
Bitcoin 계약의 고급 주문 유형 이해 Bitcoin 선물 거래 세계에서 고급 주문 유형은 위험 관리, 전략 자동화 및 실행 효율성 향상에 중요한 역할을합니다. 이러한 주문 유형은 기본 시장을 넘어서서 주문을 제한하며 거래자는 직책에 입력하거나 종료하기위한 조건부 ...

암호화 선물 거래에서 일반적인 실수
2025-07-20 21:56:36
위험 관리없이 과도하게 보입니다 암호화 선물 거래에서 가장 일반적인 실수 중 하나는 과도하게 진행 됩니다. 거래자들은 종종 높은 레버리지를 사용하면 이익을 크게 증가시킬 것이라고 생각하지만, 이는 또한 상당한 손실의 위험을 증가시킵니다. 중단 손실 주문을 설정하지 못하...
모든 기사 보기
