시가총액: $2.8167T -5.61%
거래량(24시간): $179.5196B 61.64%
공포와 탐욕 지수:

38 - 두려움

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

언어 선택

언어 선택

통화 선택

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

재진입 공격으로부터 스마트 계약을 보호하는 방법은 무엇입니까?

Reentrancy vulnerabilities arise when external calls precede state updates, enabling malicious recursive calls—mitigated by Checks-Effects-Interactions, ReentrancyGuard, and cautious gas limits.

2026/01/23 10:39

재진입 취약점 이해

1. 재진입 공격은 초기 기능 실행이 완료되기 전에 외부 계약의 기능을 이용하여 취약한 계약을 다시 호출합니다.

2. 이는 외부 호출 전에 상태 변경이 완료되지 않아 악성 코드가 잔액이나 플래그를 반복적으로 조작할 수 있는 경우에 발생합니다.

3. 2016년 악명 높은 DAO 해킹은 반복적인 인출 패턴으로 인해 6천만 달러 상당의 ETH가 어떻게 유출되었는지를 보여주었습니다.

4. 이러한 취약점은 이체, 출금 또는 상태 업데이트에 따른 외부 호출 과 관련된 모든 논리를 처리하는 기능에서 활발하게 발생합니다.

5. 0.8.0 이전의 Solidity 버전에는 재진입 가드가 내장되어 있지 않아 레거시 배포에 수동 보호가 필수적입니다.

검사-효과-상호작용 패턴 구현

1. 이 아키텍처 분야에서는 모든 내부 상태 수정이 외부 상호 작용 이전에 발생하도록 요구합니다.

2. 예를 들어, 사용자의 잔액을 업데이트하려면 전화를 호전환 하거나 다른 주소로 전화를 걸기 전에 이루어져야 합니다.

3. 이 명령을 위반하면 공격자가 제어 흐름을 탈취하고 동일한 기능에 다시 들어갈 수 있는 문이 열립니다.

4. 순서가 적절하더라도 개발자는 이벤트 발생기나 수정자와 같은 중간 기능이 의도하지 않은 외부 호출을 트리거하지 않는지 확인해야 합니다.

5. Slither 및 MythX와 같은 도구는 바이트코드 및 소스의 정적 분석 중에 이 패턴의 편차를 감지할 수 있습니다.

ReentrancyGuard 수정자 사용

1. OpenZeppelin의 ReentrancyGuard는 부울 플래그를 사용하여 기능을 잠그는 널리 감사되는 유틸리티입니다.

2. 수정자는 실행 전에 _status를 _ENTERED 로 설정하고 완료 후에는 _NOT_ENTERED 로 재설정합니다.

3. 동일한 보호 기능을 다시 시작하려고 시도하는 중첩된 호출은 활성 잠금으로 인해 되돌려집니다.

4. 모든 중요한 진입점이 동일한 가드 인스턴스를 공유하지 않는 한 기능 간 재진입을 방지하지 않습니다.

5. 개발자는 상속 계층 구조가 가드 상태를 올바르게 초기화하고 내부 변수에 대한 섀도잉을 방지하는지 확인해야 합니다.

완화 전략으로서의 가스 제한

1. call.gas(2300) 와 같은 하위 수준 호출에서 전달되는 가스를 명시적으로 제한하면 수신자 계약이 복잡한 논리를 실행하는 것을 방지할 수 있습니다.

2. 이 기술은 전송전송 의 가스 비용을 모방하여 실행을 2300 가스로 제한합니다.

3. 그러나 가스 한도에만 의존하는 것은 취약합니다. 향후 EVM 업그레이드 또는 맞춤형 opcode로 인해 가스 비용이 예측할 수 없게 변경될 수 있습니다.

4. 또한 로깅이나 재조정을 수행하는 계약과 같이 폴백 로직을 위해 최소한의 가스 이상이 필요한 계약과의 호환성을 깨뜨립니다.

5. 가스 기반 완화는 재진입 보호 장치 및 주정부 명령과 같은 구조적 보호 장치를 대체하는 것이 아니라 보완해야 합니다.

자주 묻는 질문

Q: 뷰나 순수 함수에서 재진입이 발생할 수 있나요? A: 아니요. 이러한 함수는 상태 변경 작업이나 외부 호출을 실행할 수 없으므로 재귀 간섭 가능성이 제거됩니다.

Q: Delegatecall을 사용하면 재진입이 방지됩니까? A: 본질적으로는 그렇지 않습니다. Delegatecall은 호출자의 스토리지 컨텍스트를 유지하지만 대상 논리에 보호되지 않은 외부 상호 작용이 포함된 경우 재진입 패턴을 차단하지 않습니다.

Q: Payable Fallback 기능은 항상 위험한가요? A: 재진입 보호 없이 상태 업데이트나 외부 호출을 수행하는 경우에만 해당됩니다. 부작용 없이 ETH를 수용하는 최소한의 대체는 무시할 수 있는 위험을 초래합니다.

Q: 업그레이드 가능한 프록시 패턴이 재진입 노출을 늘리나요? A: 예. 구현 계약에 적절한 보호 장치가 부족하고 프록시가 유효성 검사 없이 호출을 전달하는 경우 공격자는 프록시 논리와 비즈니스 논리를 동시에 이용할 수 있습니다.

부인 성명:info@kdj.com

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

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

관련 지식

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

2026-01-18 13:19:39

LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

안전한 서명 검증을 위해 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을 구축하는 방법은 무엇입니까?

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

2026-01-18 11:19:49

OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

LayerZero 계약으로 크로스체인 메시지를 실행하는 방법은 무엇입니까?

2026-01-18 13:19:39

LayerZero 아키텍처 이해 1. LayerZero는 신뢰할 수 있는 중개자나 래핑된 자산에 의존하지 않고 블록체인 간의 통신을 가능하게 하는 경량의 무허가 상호 운용성 프로토콜로 작동합니다. 2. 각 체인에 배포된 Ultra Light Node(ULN)를 활용하여...

안전한 서명 검증을 위해 EIP-712를 구현하는 방법은 무엇입니까?

안전한 서명 검증을 위해 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을 구축하는 방법은 무엇입니까?

OpenZeppelin 계약을 사용하여 안전한 dApp을 구축하는 방법은 무엇입니까?

2026-01-18 11:19:49

OpenZeppelin 계약 기본 사항 이해 1. OpenZeppelin Contracts는 Ethereum 및 EVM 호환 블록체인용으로 구축된 재사용 가능한 커뮤니티 감사 스마트 계약 구성 요소 라이브러리입니다. 2. 라이브러리의 각 계약은 검사-효과-상호작용 패턴...

모든 기사 보기

User not found or password invalid

Your input is correct