시가총액: $3.3432T -2.41%
거래량(24시간): $219.3876B 35.06%
공포와 탐욕 지수:

25 - 두려움

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

언어 선택

언어 선택

통화 선택

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

Solidity에서 지불 가능한 기능과 지불 불가능한 기능의 차이점은 무엇입니까?

In Solidity, only functions marked `payable` can receive Ether, preventing accidental or malicious fund transfers and ensuring secure contract design.

2025/11/14 13:59

Solidity의 함수 수정자 이해

Solidity에서는 스마트 계약 내의 기능에 Ether와 상호 작용하는 방식을 지정하는 특정 수정자가 할당될 수 있습니다. 이러한 수정자는 함수가 실행 중에 자금을 받을 수 있는지 여부를 결정하는 데 중요한 역할을 합니다. 지불 가능한 기능과 지불 불가능한 기능의 차이는 거래의 일부로 Ether를 허용하는 능력에 있습니다.

지급 기능: Ether 이체 수락

1. 지불 가능 함수는 호출 시 Ether를 수신할 수 있도록 지불 가능 수정자로 명시적으로 표시됩니다.

  1. 사용자가 지불 기능을 호출하는 거래와 함께 Ether를 보내면 자금이 계약 잔액으로 이체됩니다.
  2. 지불 가능 수정자가 없으면 Ether를 함수로 보내려고 하면 트랜잭션이 실패하게 됩니다.
  3. 지불 가능 기능은 크라우드 펀딩, 기부 또는 사용자가 기능 호출을 통해 직접 자금을 기부하는 메커니즘과 같은 기능에 필수적입니다.
  4. 지불 기능 내에서 개발자는 수신된 wei 수를 보유하는 msg.value 를 사용하여 전송된 금액에 액세스할 수 있습니다.

비지급 기능: 들어오는 Ether 거부

1. 기본적으로 Solidity의 기능은 별도로 지정하지 않는 한 지불할 수 없습니다.

  1. 거래가 지불 불가능한 기능으로 Ether를 보내려고 시도하는 경우 우발적인 자금 손실을 방지하기 위해 전체 거래가 되돌려집니다.
  2. 이 동작은 의도하지 않은 Ether 전송으로부터 사용자와 계약 논리를 모두 보호합니다.
  3. 비지불 기능은 재정적 입력 없이 상태를 수정하거나 데이터를 읽는 작업에만 적합합니다.
  4. 함수가 Ether를 기대하지 않더라도 msg.value > 0 으로 호출하면 지불 가능으로 표시되지 않은 경우 런타임 예외가 발생합니다.

스마트 계약 설계의 실제적 의미

1. 자금을 받아야 할 때 기능을 미지급으로 잘못 표시하면 토큰 구매 또는 스테이킹 메커니즘과 같은 핵심 기능이 손상될 수 있습니다.

  1. 반대로, 불필요한 기능을 지불 가능으로 표시하면 특히 msg.value 에 대한 적절한 유효성 검사가 누락된 경우 공격 표면이 증가합니다.
  2. 개발자는 Ether 흐름이 올바르게 처리되도록 모든 외부 연결 기능을 주의 깊게 감사해야 합니다.
  3. 정적 분석기 및 테스트 프레임워크와 같은 도구는 배포 전에 지불 수정자의 잘못된 사용을 감지하는 데 도움이 됩니다.
  4. 복잡한 계약에서 자금 수령 기능과 유틸리티 기능을 구별하면 코드 명확성과 보안이 향상됩니다.

자주 묻는 질문

건설업자에게 비용을 지불할 수 있나요? 예, 건설업자는 지불 가능으로 표시될 수 있습니다. 이를 통해 계약은 배포 중에 Ether를 수락할 수 있습니다. 배포 트랜잭션에 가치 이전이 포함된 경우 되돌리기를 방지하려면 생성자에게 비용을 지불해야 합니다.

Ether로 지불할 수 없는 함수를 호출하면 어떻게 되나요? 트랜잭션은 자동으로 되돌려지고 상태 변경은 발생하지 않습니다. Ethereum은 실수로 Ether를 처리하도록 설계되지 않은 기능으로 전송하는 것을 방지하기 위해 EVM 수준에서 이 규칙을 시행합니다.

기본적으로 계약의 모든 기능을 지불할 수 있도록 하는 방법이 있습니까? 아니요. 각 기능은 개별적으로 지불 가능으로 선언되어야 합니다. 모든 기능이 Ether를 허용하도록 하는 전역 설정은 없습니다. 이 설계는 자금 수령의 의도적이고 안전한 처리를 보장합니다.

대체 기능이 지불 가능하지 않은 경우 Ether를 받을 수 있나요? 아니요. 대체 기능도 Ether를 허용하려면 지불 가능으로 표시되어야 합니다. 지불 불가능한 폴백 함수는 함수 호출을 지정하지 않고 계약으로 전송된 들어오는 Ether를 거부합니다.

부인 성명:info@kdj.com

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

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

관련 지식

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

2025-11-10 05:20:08

스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

2025-11-11 05:59:39

블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

2025-11-11 22:40:12

Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

2025-11-13 04:00:32

외부 소유 계정(EOA) 이해 1. 외부 소유 계정은 개인 키로 직접 제어됩니다. 즉, 해당 키 소유자만 계정에서 거래를 시작할 수 있습니다. EOA에는 관련 코드가 없습니다. 이는 블록체인에서 거래를 보내고 받는 데 사용되는 간단한 주소입니다. 이러한 계정은 일반적으...

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

2025-11-13 05:39:54

ERC-2981 NFT 로열티 표준 이해 1. ERC-2981 표준은 대체 불가능한 토큰(NFT)에 대한 로열티 메커니즘을 도입하는 제안된 이더리움 의견 요청입니다. 로열티에 대한 기본 지원이 부족한 ERC-721 및 ERC-1155와 같은 이전 NFT 표준과 달리 E...

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

2025-11-12 11:39:42

최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

스마트 계약에서 서비스 거부(DoS) 공격이란 무엇이며 일반적인 형태는 무엇입니까?

2025-11-10 05:20:08

스마트 계약의 서비스 거부 이해 1. 스마트 계약의 맥락에서 서비스 거부(DoS) 공격은 악의적인 행위자가 합법적인 사용자가 계약 기능에 액세스하거나 사용하는 것을 막는 시나리오를 의미합니다. 이는 일반적으로 공격자가 중요한 작업을 차단할 수 있도록 하는 설계 결함을 ...

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

거래 서명에 사용되는 암호화 임시값은 무엇입니까?

2025-11-11 05:59:39

블록체인 거래의 암호화 임시값 이해 1. 암호화 논스는 블록체인 네트워크 내에서 거래 서명의 맥락에서 한 번만 사용되는 난수 또는 의사 난수입니다. 주요 기능은 각 트랜잭션이 고유하고 악의적인 행위자가 재생할 수 없도록 하는 것입니다. nonce가 없으면 동일한 거래가...

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

Solidity 스마트 계약에서 상속은 어떻게 작동하나요?

2025-11-11 22:40:12

Solidity의 상속: 모듈식 스마트 계약 구축 1. Solidity의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

외부 소유 계정(EOA)과 계약 계정의 차이점은 무엇입니까?

2025-11-13 04:00:32

외부 소유 계정(EOA) 이해 1. 외부 소유 계정은 개인 키로 직접 제어됩니다. 즉, 해당 키 소유자만 계정에서 거래를 시작할 수 있습니다. EOA에는 관련 코드가 없습니다. 이는 블록체인에서 거래를 보내고 받는 데 사용되는 간단한 주소입니다. 이러한 계정은 일반적으...

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

ERC-2981 NFT 로열티 표준은 무엇이며 어떻게 작동합니까?

2025-11-13 05:39:54

ERC-2981 NFT 로열티 표준 이해 1. ERC-2981 표준은 대체 불가능한 토큰(NFT)에 대한 로열티 메커니즘을 도입하는 제안된 이더리움 의견 요청입니다. 로열티에 대한 기본 지원이 부족한 ERC-721 및 ERC-1155와 같은 이전 NFT 표준과 달리 E...

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?

2025-11-12 11:39:42

최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...

모든 기사 보기

User not found or password invalid

Your input is correct