-
bitcoin $102114.324364 USD
-1.15% -
ethereum $3431.987185 USD
-0.20% -
tether $0.999774 USD
0.01% -
xrp $2.413274 USD
0.63% -
bnb $955.503627 USD
-0.78% -
solana $153.024806 USD
-1.14% -
usd-coin $0.999773 USD
-0.01% -
tron $0.294622 USD
-1.49% -
dogecoin $0.171145 USD
-0.74% -
cardano $0.550988 USD
-1.47% -
hyperliquid $38.642694 USD
-1.48% -
chainlink $15.306723 USD
-0.57% -
bitcoin-cash $515.781451 USD
1.70% -
stellar $0.281692 USD
-0.39% -
unus-sed-leo $9.147081 USD
-0.64%
Solidity의 수정자는 무엇이며 액세스 제어에 어떻게 사용됩니까?
Modifiers in Solidity control function behavior, enabling reusable access checks like ownership or roles, enhancing security and reducing code duplication.
2025/11/11 15:39
Solidity의 수정자 이해
1. Solidity의 수정자는 개발자가 선언적인 방식으로 함수의 동작을 변경할 수 있도록 하는 코드 구성입니다. 일반적으로 여러 함수에 걸쳐 코드를 반복하지 않고 함수 실행 전후에 추가 논리를 주입하는 데 사용됩니다. 수정자는 수정자 키워드 뒤에 이름과 밑줄 _로 끝나는 코드 블록을 사용하여 정의됩니다. , 함수 본문을 삽입해야 하는 위치를 나타냅니다.
2. 수정자의 가장 일반적인 사용 사례 중 하나는 스마트 계약 내에서 액세스 제어를 시행하는 것입니다. 호출자가 계약 소유자인지 여부와 같은 특정 조건을 확인하는 수정자를 정의함으로써 개발자는 특정 기능을 호출할 수 있는 사람을 제한할 수 있습니다. 이는 모든 제한된 기능 내에서 동일한 조건을 수동으로 확인할 필요가 없기 때문에 중복성을 줄이고 코드 가독성을 높입니다.
3. 예를 들어 계약 배포자의 주소를 저장한 다음 함수 호출 중에 msg.sender 와 비교하여 간단한 onlyOwner 수정자를 생성할 수 있습니다. 보낸 사람이 저장된 소유자 주소와 일치하면 기능이 진행됩니다. 그렇지 않으면 실행이 되돌려집니다. 이 패턴은 소유권 기반 계약에서 널리 채택되며 많은 액세스 제어 체계의 기초를 형성합니다.
4. 수정자는 결합하거나 쌓을 수도 있습니다. 단일 함수에 여러 수정자를 적용할 수 있으며 나열된 순서대로 실행됩니다. 각 수정자는 함수 본문을 실행하기 위한 조건을 전달해야 합니다. 이를 통해 계층화된 보안 검사가 가능합니다. 예를 들어 상태 변경을 허용하기 전에 소유권과 운영 상태를 모두 확인합니다.
5. 수정자에는 자체 반환 값이 없다는 점에 유의하는 것이 중요합니다. 대신 수정하는 기능의 흐름에 영향을 줍니다. 밑줄 자리 표시자를 생략하면 함수 본문이 실행되지 않으므로 필수적입니다. 부적절하게 사용하면 특히 복잡한 조건부 논리에서 자동 실패나 의도하지 않은 되돌리기가 발생할 수 있습니다.
역할 기반 액세스 제어 구현
1. 단순한 소유권을 넘어 수정자는 역할 기반 권한과 같은 보다 정교한 액세스 제어 모델을 가능하게 합니다. 이 접근 방식에서는 서로 다른 주소에 관리자, 민터 또는 일시 중지와 같은 특정 역할이 할당되며 올바른 역할을 가진 사람만이 특정 기능을 호출할 수 있습니다. 이는 주소에서 부울 플래그로의 매핑을 유지하거나 OpenZeppelin의 AccessControl 과 같은 전용 라이브러리를 사용하여 구현됩니다.
2. 기능 실행을 허용하기 전에 이러한 역할 할당을 확인하기 위해 onlyAdmin 또는 onlyMinter 와 같은 사용자 정의 한정자를 작성할 수 있습니다. 이러한 검사는 권한 있는 작업이 승인된 참가자에게만 국한되도록 보장하여 보안을 강화합니다.
3. 역할 기반 시스템에는 역할을 부여하거나 취소하는 관리 기능이 포함되는 경우가 많습니다. 이러한 관리 작업 자체는 일반적으로 최고 관리자 또는 다중 서명 지갑으로 제한되는 더 높은 권한 수정자를 사용하여 보호되어 무단 권한 상승을 방지합니다.
4. 수정자 내의 이벤트를 사용하면 액세스가 허용되거나 거부되는 시기를 추적하는 데 도움이 될 수 있습니다. 역할이 변경되거나 제한된 기능이 호출될 때마다 로그를 내보내면 투명성을 제공하고 분산 애플리케이션에 사용되는 오프체인 모니터링 도구를 지원합니다.
5. 이러한 패턴은 업그레이드 가능성과 거버넌스를 활성화하는 동시에 시스템 무결성을 유지하기 위해 세분화된 권한 부여가 필요한 토큰 계약, NFT 마켓플레이스 및 DeFi 프로토콜에서 널리 퍼져 있습니다.
모범 사례 및 보안 고려 사항
1. 수정자를 디자인할 때는 명확성과 예측 가능성이 중요합니다. 수정자 내부의 논리는 감사 또는 업그레이드 중에 오해를 방지하기 위해 간단하고 잘 문서화되어야 합니다. 꼭 필요한 경우가 아니면 복잡한 중첩 조건은 피해야 합니다.
2. 개발자는 제한이 필요한 모든 상태 변경 기능이 적절하게 보호되는지 확인해야 합니다. 필요한 수정자를 적용하는 것을 잊어버리는 것은 누구나 토큰을 발행하거나 자금을 인출할 수 있도록 허용하는 등 심각한 취약점을 초래할 수 있는 일반적인 실수입니다.
3. 수정자가 외부 계약과 상호 작용하거나 적절한 보호 조치 없이 가치를 이전하는 경우 반복 호출 또는 재진입 위험이 나타날 수 있습니다. 수정자를 재진입이 불가능한 가드와 결합하면 특히 금융 애플리케이션에서 이러한 위협을 완화하는 데 도움이 됩니다.
4. 수정자를 철저히 테스트하는 것이 필수적입니다. 단위 테스트는 성공적인 실행과 승인되지 않은 조건에서의 되돌리기를 모두 확인해야 합니다. Hardhat 및 Foundry와 같은 도구는 다양한 계정 유형의 시뮬레이션된 트랜잭션을 통해 수정자 동작 테스트를 지원합니다.
5. 상속은 수정자가 적용되는 방식에 영향을 줄 수 있습니다. 파생 계약의 기능을 재정의할 때 개발자는 명시적으로 달리 의도하지 않는 한 원래 수정자를 유지해야 함을 기억해야 합니다. 그렇게 하지 않으면 상속된 기능이 의도하지 않은 액세스에 노출될 수 있습니다.
자주 묻는 질문
수정자에 밑줄(_) 문이 포함되지 않으면 어떻게 되나요? 수정자가 밑줄을 생략하면 수정하려는 함수 본문이 실행되지 않습니다. 수정자의 코드는 실행되지만 제어는 실제 함수에 도달하지 않으므로 모든 조건이 충족되더라도 실행이 효과적으로 차단됩니다.
함수에 수정자가 두 개 이상 있을 수 있나요? 예, 여러 수정자를 사용하여 함수에 주석을 달 수 있습니다. 함수 선언에 나타나는 순서대로 실행됩니다. 각 수정자는 밑줄에 도달하여 성공적으로 완료되어야 다음 수정자가 진행되고 궁극적으로 함수 본문이 실행됩니다.
매개변수는 수정자에 어떻게 전달됩니까? 수정자는 함수와 마찬가지로 매개변수를 허용할 수 있습니다. 수정자를 함수에 적용할 때 인수는 괄호 안에 전달됩니다. 이를 통해 호출 시 정의된 특정 주소나 임계값을 확인하는 등의 동적 동작이 가능합니다.
Solidity에서 수정자를 상속할 수 있나요? 예, 기본 계약에 정의된 수정자는 비공개로 표시되지 않은 경우 파생 계약에 액세스할 수 있습니다. 내부 또는 공용 수정자를 하위 계약에서 재사용하여 프로젝트 계약 계층 전반에 걸쳐 모듈식 및 재사용 가능한 액세스 제어 논리를 촉진할 수 있습니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- Airdrop Anarchy: 암호화폐 서부의 조작 폭로
- 2025-11-14 04:55:01
- dYdX, 환매 프로그램 및 커뮤니티: DeFi의 새로운 시대?
- 2025-11-14 04:50:01
- DYDX가 올인합니다: 프로토콜 수수료로 인해 대규모 토큰 환매가 촉진됩니다.
- 2025-11-14 04:50:02
- 밀크 모카 밈 코인 사전 판매 열풍: HUGS가 하트와 암호화폐를 훔칩니다.
- 2025-11-14 02:50:01
- 애스터 가격, 시장 강점, 미래 전망: 강세 신호?
- 2025-11-14 03:40:02
- eBay 50p Coin Frenzy: 당신은 숨겨진 행운을 누리고 있습니까?
- 2025-11-14 03:22:21
관련 지식
스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?
2025-11-10 05:20:08
스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...
거래 서명에 사용되는 암호화 임시값은 무엇입니까?
2025-11-11 05:59:39
블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...
Solidity 스마트 계약에서 상속은 어떻게 작동하나요?
2025-11-11 22:40:12
Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...
외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?
2025-11-13 04:00:32
외부 소유 계정(EOA) 이해 1. 외부 소유 계정은 개인 키로 직접 제어됩니다. 즉, 해당 키 소유자만 계정에서 거래를 시작할 수 있습니다. EOA에는 관련 코드가 없습니다. 이는 블록체인에서 거래를 보내고 받는 데 사용되는 간단한 주소입니다. 이러한 계정은 일반적으...
ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?
2025-11-13 05:39:54
ERC-2981 NFT 로열티 표준 이해 1. ERC-2981 표준은 대체 불가능한 토큰(NFT)에 대한 로열티 메커니즘을 도입하는 제안된 이더리움 의견 요청입니다. 로열티에 대한 기본 지원이 부족한 ERC-721 및 ERC-1155와 같은 이전 NFT 표준과 달리 E...
최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?
2025-11-12 11:39:42
최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...
스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?
2025-11-10 05:20:08
스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...
거래 서명에 사용되는 암호화 임시값은 무엇입니까?
2025-11-11 05:59:39
블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...
Solidity 스마트 계약에서 상속은 어떻게 작동하나요?
2025-11-11 22:40:12
Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...
외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?
2025-11-13 04:00:32
외부 소유 계정(EOA) 이해 1. 외부 소유 계정은 개인 키로 직접 제어됩니다. 즉, 해당 키 소유자만 계정에서 거래를 시작할 수 있습니다. EOA에는 관련 코드가 없습니다. 이는 블록체인에서 거래를 보내고 받는 데 사용되는 간단한 주소입니다. 이러한 계정은 일반적으...
ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?
2025-11-13 05:39:54
ERC-2981 NFT 로열티 표준 이해 1. ERC-2981 표준은 대체 불가능한 토큰(NFT)에 대한 로열티 메커니즘을 도입하는 제안된 이더리움 의견 요청입니다. 로열티에 대한 기본 지원이 부족한 ERC-721 및 ERC-1155와 같은 이전 NFT 표준과 달리 E...
최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?
2025-11-12 11:39:42
최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...
모든 기사 보기














