시가총액: $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
비디오

Solidity로 첫 번째 스마트 계약을 작성하는 방법은 무엇입니까? (단계별 튜토리얼)

Set up Node.js, Truffle, and Ganache; write an ERC-20 token using OpenZeppelin; compile, deploy locally, and test via Truffle console and JavaScript.

2026/01/17 00:00

개발 환경 설정

1. Node.js와 npm을 설치하여 Solidity 도구에 필요한 종속성을 관리합니다.

2. npm을 사용하여 Ethereum 기반 스마트 계약을 위해 널리 채택되는 개발 프레임워크인 Truffle을 전 세계적으로 설치합니다.

3. 로컬 테스트를 위해 Ganache를 개인 블록체인으로 설치합니다. ETH가 사전 자금으로 개인 계정에 제공됩니다.

4. truffle init을 사용하여 contract/ , migrations/test/ 와 같은 필수 디렉터리를 생성하는 새로운 Truffle 프로젝트를 구성합니다.

5. truffle 버전을 실행하고 Solidity 컴파일러 v0.8.x 이상과의 호환성을 확인하여 설치 무결성을 확인합니다.

기본 토큰 계약 작성

1. contract/ 폴더 안에 MyToken.sol 이라는 새 파일을 생성합니다.

2. Solidity 버전 pragma를 선언합니다. pragma solidity ^0.8.20; 결정론적 컴파일 동작을 보장합니다.

3. OpenZeppelin의 ERC-20 구현 가져오기: import '@openzeppelin/contracts/token/ERC-20/ERC-20.sol';

4. 계약 상속을 정의합니다. 계약 MyToken은 ERC20 { ... } 이며 생성자에서 이름, 기호 및 총 공급량을 초기화합니다.

5. OpenZeppelin의 AccessControl 라이브러리에서 onlyOwner 수정자를 사용하여 소유자로 제한된 민트 기능을 추가합니다.

계약 컴파일 및 배포

1. migrations/2_deploy_contracts.js 에 마이그레이션 스크립트를 작성하여 1백만 개의 토큰으로 MyToken을 인스턴스화하고 배포합니다.

2. 트러플 컴파일을 실행하여 ABI 및 바이트코드를 생성합니다. 구문 또는 버전 불일치 오류가 나타나지 않는지 확인하십시오.

3. Ganache를 실행하고 RPC 서버 URL(예: http://127.0.0.1:7545)을 개발 네트워크 아래의 truffle-config.js 에 복사합니다.

4. truffle migration --network development를 실행하여 계약을 배포하고 거래 해시와 계약 주소를 기록합니다.

5. Ganache의 트랜잭션 로그를 확인하고 콘솔 출력에 계약 주소가 나타나는지 확인하여 배포 성공을 확인합니다.

Truffle 콘솔을 통한 상호작용

1. Ganache에 연결된 Truffle 콘솔을 시작합니다: truffle console --network development .

2. 배포된 인스턴스를 가져옵니다. let 인스턴스 = wait MyToken.deployed();

3. (await instance.totalSupply()).toString()을 사용하여 총 공급량을 쿼리합니다. — 초기 민트 값과 일치하는 출력을 기대합니다.

4. 계정 간 토큰 전송: wait instance.transfer('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5', '1000') .

5. (await instance.balanceOf('0xAb8483F64d9C6d1EcF9b849Ae677dC320f55a1B5')).toString() 을 사용하여 잔액 변경 사항을 확인합니다.

자바스크립트로 테스트

1. 핵심 기능에 대한 Mocha 스타일 테스트 사례가 포함된 test/mytoken.js를 만듭니다.

2. contract()를 사용하여 테스트 컨텍스트를 정의하고 it() 블록을 사용하여 발행, 전송 및 이벤트 방출과 같은 동작을 주장합니다.

3. transfer를 호출한 후 Assert.equal(receipt.logs[0].event, 'Transfer') 를 사용하여 올바른 이벤트 로그를 확인합니다.

4. 복귀 조건 테스트: 잔액 이상의 이체를 시도하고 ExpectRevert 유틸리티를 사용하여 복귀 가 발생하는지 확인합니다.

5. 트러플 테스트 로 테스트를 실행하고 시간 초과나 런타임 예외 없이 모든 어설션이 통과하는지 확인합니다.

자주 묻는 질문

Q: Truffle을 사용하지 않고 Solidity 계약을 배포할 수 있나요? 답: 그렇습니다. 대안으로는 Hardhat, Remix IDE 또는 컴파일된 바이트코드 및 ABI를 사용한 직접 web3.js 호출이 있습니다.

Q: ETH를 받는 함수에서 지불 가능 키워드를 잊어버리면 어떻게 되나요? 답변: 이 기능은 ETH 전송을 시도하는 모든 거래를 되돌려 실행 실패와 가스 소비를 초래합니다.

Q: 액세스 제어에 tx.origin을 사용해도 안전합니까? A: 아니요. tx.origin은 피싱 계약을 통해 조작될 수 있으며 권한 확인에서 msg.sender를 대체해서는 안 됩니다.

Q: Etherscan에서 내 계약 소스 코드를 어떻게 확인하나요? A: Etherscan의 확인 양식을 통해 정확한 Solidity 소스, 컴파일러 버전, 최적화 설정 및 생성자 인수를 제출하세요.

부인 성명: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