-
bitcoin $103299.489104 USD
-2.75% -
ethereum $3438.818401 USD
-4.09% -
tether $0.999694 USD
-0.02% -
xrp $2.398080 USD
-5.09% -
bnb $962.992856 USD
-3.68% -
solana $154.795444 USD
-7.73% -
usd-coin $0.999881 USD
-0.02% -
tron $0.299080 USD
0.51% -
dogecoin $0.172414 USD
-4.61% -
cardano $0.559226 USD
-5.94% -
hyperliquid $39.224649 USD
-5.04% -
chainlink $15.394534 USD
-6.06% -
bitcoin-cash $506.933641 USD
-2.17% -
stellar $0.282786 USD
-5.75% -
unus-sed-leo $9.205805 USD
-0.38%
Solidity로 간단한 스마트 계약을 만드는 방법은 무엇입니까?
Set up your Solidity dev environment with Node.js, Hardhat, and the Solidity compiler, then write, compile, and test a basic contract like Lock.sol locally.
2025/11/06 05:30
개발 환경 설정
1. Node.js와 npm을 설치하여 종속성을 관리하고 Solidity 개발에 필요한 로컬 도구를 실행합니다.
2. npm을 사용하여 스마트 계약 작성, 테스트 및 배포를 지원하는 강력한 Ethereum 개발 환경인 Hardhat을 설치합니다.
3. 기본 폴더 구조와 구성 파일을 설정하는 터미널에서 npx hardhat을 사용하여 새 Hardhat 프로젝트를 초기화합니다.
4. 대상 EVM 버전과의 호환성을 보장하기 위해 Hardhat의 플러그인 시스템을 통해 종속 항목으로 추가하여 Solidity 컴파일러를 설치합니다.
5. 계약 디렉터리 내에 Lock.sol 이라는 새 파일을 생성하여 첫 번째 계약 작성을 시작합니다.
Solidity에서 기본 스마트 계약 작성
1. pragma solidity ^0.8.0 과 같이 컴파일러 버전을 지정하는 pragma 문을 사용하여 Solidity 파일을 시작합니다. .
2. 계약 키워드 뒤에 Lock 과 같은 이름을 사용하여 계약을 정의하고 모든 논리를 중괄호로 캡슐화합니다.
3. 온체인에 데이터를 저장하기 위한 상태 변수를 선언합니다. 예: uint public UnlockTime; 지불 가능한 공공 소유자의 주소; .
4. 계약이 배포될 때 한 번 실행되는 생성자를 구현하고 소유자 및 잠금 해제 타임스탬프와 같은 초기 값을 설정합니다.
5. 한정자를 사용하여 액세스 제어를 포함하거나 특정 시간 이후 소유자에게 실행을 제한하는 명령문을 요구하는 철회() 와 같은 함수를 추가합니다.
Solidity의 수정자 기능을 사용하면 개발자는 여러 기능에서 유효성 검사 논리를 재사용하여 코드 가독성을 높이고 중복성을 줄일 수 있습니다.
계약을 로컬로 컴파일 및 배포
1. JavaScript 또는 TypeScript를 사용하여 스크립트 폴더에 배포 스크립트를 작성하여 계약을 인스턴스화하고 로컬 네트워크로 보냅니다.
2. 테스트 중에 실제 자금을 지출하지 않고 Hardhat의 내장 네트워크를 사용하여 Ethereum 환경을 시뮬레이션합니다.
3. 컴파일 명령 npx hardhat compile을 실행하여 구문 오류가 없는지 확인하고 ABI 아티팩트를 생성합니다.
4. npx hardhat run scripts/deploy.js를 통해 배포 스크립트를 실행하여 계약을 로컬 노드에 배포합니다.
5. 후속 단계에서 상호 작용 및 확인을 위해 배포된 계약 주소를 캡처합니다.
스마트 계약 동작 테스트
1. 소유권 및 시간 기반 출금 규칙과 같은 핵심 기능을 검증하기 위해 테스트 디렉터리에 테스트 파일을 만듭니다.
2. 테스트 내에서 ethers.js를 사용하여 배포된 계약 인스턴스와 상호 작용하고 사용자 작업을 시뮬레이션합니다.
3. Mocha 스타일 설명 및 블록을 사용하여 테스트 케이스를 명확하게 구성하고 Chai 어설션을 사용하여 예상 결과를 주장합니다.
4. 조기 출금 시도, 무단 접근 등의 엣지 케이스를 시뮬레이션하여 보안 제약 조건을 확인합니다.
5. 외부 배포를 고려하기 전에 npx hardhat 테스트를 사용하여 전체 테스트 제품군을 실행하여 안정성을 확인합니다.
자주 묻는 질문
Solidity 코드를 편안하게 작성하려면 어떤 도구를 사용할 수 있나요? 인기 있는 옵션으로는 Solidity 확장이 포함된 Visual Studio Code, 브라우저 기반 편집을 위한 Remix IDE, 통합 테스트 및 배포 워크플로를 위한 Hardhat이 있습니다.
Solidity에서 정수 오버플로를 어떻게 처리합니까? Solidity 0.8.0부터 산술 연산은 오버플로 및 언더플로를 자동으로 확인하고 감지되면 트랜잭션을 되돌립니다. 이전 버전을 사용하지 않는 한 SafeMath와 같은 외부 라이브러리에 의존할 필요가 없습니다.
배포 후 스마트 계약을 수정할 수 있나요? 아니요, 배포된 계약은 변경할 수 없습니다. 모든 변경 사항에는 새 인스턴스를 다시 배포해야 합니다. 개발자는 종종 프록시 패턴을 사용하여 데이터 연속성을 유지하면서 업그레이드 가능성을 시뮬레이션합니다.
Solidity 프로젝트에서 ABI의 목적은 무엇입니까? ABI(Application Binary Interface)는 계약, 목록 함수, 매개변수 및 반환 유형과 상호 작용하는 방법을 정의합니다. 프런트엔드와 외부 도구가 계약 메서드를 올바르게 호출하는 것이 중요합니다.
부인 성명:info@kdj.com
제공된 정보는 거래 조언이 아닙니다. kdj.com은 이 기사에 제공된 정보를 기반으로 이루어진 투자에 대해 어떠한 책임도 지지 않습니다. 암호화폐는 변동성이 매우 높으므로 철저한 조사 후 신중하게 투자하는 것이 좋습니다!
본 웹사이트에 사용된 내용이 귀하의 저작권을 침해한다고 판단되는 경우, 즉시 당사(info@kdj.com)로 연락주시면 즉시 삭제하도록 하겠습니다.
- DESK 토큰, 토큰화된 부동산 및 벤처 허브: 디지털 자산의 새로운 시대
- 2025-11-12 16:55:02
- JPM 코인, 블록체인, 퍼블릭 토큰: 기관 금융의 미래?
- 2025-11-12 17:10:00
- Ethereum의 고래 감시: 업그레이드가 시작됩니다!
- 2025-11-12 17:10:00
- DOGE: 가격과 잠재력 분석 – Dogecoin이 1달러에 도달할 수 있을까요?
- 2025-11-12 17:10:02
- JPMD, USD 토큰 및 기본 네트워크: JPMorgan의 블록체인 도약
- 2025-11-12 17:10:02
- Treasury는 진화를 진행합니다: 블록체인 엔지니어링을 통해 MSTR을 넘어
- 2025-11-12 17:20:01
관련 지식
스마트 계약에서 서비스 거부(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의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...
최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?
2025-11-12 11:39:42
최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...
Solidity의 라이브러리는 무엇이며 기본 계약과 어떻게 다릅니까?
2025-11-12 09:19:55
Solidity의 라이브러리 이해 1. Solidity의 라이브러리는 상속되지 않고 여러 계약에서 공유할 수 있는 재사용 가능한 기능을 보유하도록 설계된 특별한 유형의 계약입니다. 이러한 함수는 상태 비저장입니다. 즉, 다른 계약의 저장소와 명시적으로 상호 작용하지 않...
Ether를 다른 계약으로 안전하게 보내는 방법은 무엇입니까?
2025-11-09 18:40:05
스마트 계약으로 Ether 보내기: 주요 고려 사항 1. 수신 계약에 지불 가능한 대체 기능 또는 Ether를 수용할 수 있는 지정된 지불 기능이 있는지 확인하십시오. 이것이 없으면 모든 이체가 취소되어 잠재적으로 자금이 영구적으로 잠길 수 있습니다. 2. 외부 계약과...
스마트 계약에서 서비스 거부(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의 상속을 통해 하나의 계약이 다른 계약의 속성과 기능을 채택할 수 있으므로 코드 재사용과 구조화된 설계가 가능합니다. 파생 계약은 기본 계약에서 상속할 수 있으며 비공개로 표시되지 않은 상태 변수,...
최소 프록시 계약(EIP-1167)이란 무엇이며 배포 시 가스를 어떻게 절약합니까?
2025-11-12 11:39:42
최소 프록시 계약(EIP-1167)이란 무엇입니까? 1. EIP(Ethereum Improvement Proposal) 1167에 따라 표준화된 최소 프록시 계약은 호출을 기존 구현 계약에 위임하도록 설계된 경량 계약입니다. 자체적으로 로직을 저장하지 않고 모든 함수 ...
Solidity의 라이브러리는 무엇이며 기본 계약과 어떻게 다릅니까?
2025-11-12 09:19:55
Solidity의 라이브러리 이해 1. Solidity의 라이브러리는 상속되지 않고 여러 계약에서 공유할 수 있는 재사용 가능한 기능을 보유하도록 설계된 특별한 유형의 계약입니다. 이러한 함수는 상태 비저장입니다. 즉, 다른 계약의 저장소와 명시적으로 상호 작용하지 않...
Ether를 다른 계약으로 안전하게 보내는 방법은 무엇입니까?
2025-11-09 18:40:05
스마트 계약으로 Ether 보내기: 주요 고려 사항 1. 수신 계약에 지불 가능한 대체 기능 또는 Ether를 수용할 수 있는 지정된 지불 기능이 있는지 확인하십시오. 이것이 없으면 모든 이체가 취소되어 잠재적으로 자금이 영구적으로 잠길 수 있습니다. 2. 외부 계약과...
모든 기사 보기














