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

NFT 계약(ERC-721)을 처음부터 어떻게 생성하나요?

ERC-721 mandates unique token IDs, owner tracking, and Transfer events; optional metadata via tokenURI enables rich NFTs—implemented securely using OpenZeppelin contracts.

2026/01/22 03:40

ERC-721 표준 사양 이해

1. ERC-721은 ownerOf , safeTransferFromApproval을 포함하여 모든 준수 계약이 구현해야 하는 일련의 필수 기능 및 이벤트를 정의합니다.

2. 표준은 고유한 토큰 식별자를 시행합니다. 각 NFT에는 특정 시간에 정확히 한 명의 소유자에게 매핑된 고유한 uint256 ID가 있어야 합니다.

3. 메타데이터 지원은 선택 사항이지만 널리 채택됩니다. tokenURI 함수는 이름, 설명, 이미지 링크가 포함된 JSON을 가리키는 URI를 반환합니다.

4. 전송 이벤트는 지갑과 탐색기 호환성을 보장하기 위해 from, to 및 tokenId 매개변수를 사용하여 전송을 내보내야 합니다.

5. 기본 ERC-721에서는 열거 지원이 필요하지 않지만 많은 구현에서는 마켓플레이스 인덱싱을 위해 totalSupplytokenByIndex를 추가합니다.

개발 환경 설정

1. Node.js 및 npm을 설치하여 로컬 컴파일 및 테스트를 위해 Hardhat 또는 Foundry와 같은 종속성을 관리합니다.

2. npm init -y를 사용하여 새 프로젝트를 초기화하고 npm install @openzeppelin/contracts를 통해 OpenZeppelin Contracts를 설치합니다.

3. 배포 시뮬레이션을 위해 Sepalia 또는 로컬 Anvil 네트워크에 연결하도록 Hardhat 구성 파일을 구성합니다.

4. contract 디렉터리에 MyNFT.sol 이라는 Solidity 파일을 생성하고 OpenZeppelin의 ERC721Ownable 모듈을 가져옵니다.

5. 이름 및 기호와 같은 생성자 인수를 정의한 다음 해당 값을 사용하여 상위 ERC721 생성자를 호출합니다.

핵심 계약 논리 작성

1. _baseTokenURI 상태 변수를 추가하여 계약 소유자만 업데이트하는 메타데이터의 루트 경로를 저장합니다.

2. tokenURI 함수를 재정의하여 _baseTokenURI를 tokenId 문자열과 연결하여 IPFS 또는 HTTP 엔드포인트가 올바르게 확인되도록 합니다.

3. _safeMint를 사용하여 msg.sender에만 새 토큰을 할당하고 내부 카운터를 증가시키는 민트 기능을 구현합니다.

4. 무단 메타데이터 조작을 방지하기 위해 setBaseURI 와 같은 민감한 기능에 onlyOwner 수정자를 도입합니다.

5. 0x80ac58cd(ERC-721) 및 0x5b5e139f(ERC-721 메타데이터) 인터페이스 ID에 대해 true를 반환하도록 presentsInterface 재정의를 포함합니다.

테스트넷에서 컴파일 및 배포

1. npx hardhat 컴파일을 실행하여 ABI 및 바이트코드를 생성합니다. 구문이나 상속 오류가 나타나지 않는지 확인하세요.

2. "CryptoPanda" 및 "CPANDA"를 인수로 사용하여 계약 생성자를 호출하는 배포 스크립트를 작성합니다.

3. npx hardhat run scripts/deploy.js --network sepolia를 사용하여 배포자 주소에 자금을 조달한 후 트랜잭션을 브로드캐스트합니다.

4. 컴파일 중에 사용된 것과 동일한 컴파일러 버전 및 최적화 설정을 사용하여 Etherscan Sepalia에서 계약을 확인합니다.

5. Etherscan의 "프록시로 쓰기" 또는 MetaMask에 연결된 dApp 인터페이스를 사용하여 배포된 계약과 상호 작용하여 발행 및 전송을 트리거합니다.

자주 묻는 질문

Q: 발행 후 tokenURI를 변경할 수 있나요? A: 예. 계약에서 소유자 전용 설정자 기능을 통해 이를 허용하지만 이를 변경하면 토큰별 URI를 저장하지 않는 한 이전에 발행된 모든 토큰에 소급 적용됩니다.

Q: 두 개의 토큰이 동일한 ID를 공유하면 어떻게 되나요? A: OpenZeppelin의 _owners 매핑 유효성 검사에 의해 시행되는 중복 매핑 검사로 인해 발행 중에 계약이 되돌려집니다.

Q: ERC-20보다 ERC-721의 가스 비용이 더 높나요? A: 예. ERC-721 작업에는 토큰 ID당 개별 스토리지 쓰기가 필요하므로 발행 및 전송에 대한 가스 소비가 상당히 높아집니다.

Q: 계약에 로열티를 구현해야 합니까? A: 아니요. 로열티는 ERC-721 사양의 일부가 아닙니다. OpenSea와 같은 플랫폼은 ERC-2981을 통해 구현된 경우 RoyaltyInfo 함수에서 로열티 정보를 읽습니다.

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