ERC-721

Introduction

이 튜토리얼은 Klaytn 토큰 표준(대체 불가 토큰 표준인 ERC-721과 호환)을 따르는 토큰을 만드는 방법을 소개합니다.

ERC-721 대체 불가능한 토큰 표준은 아래와 같은 3개의 이벤트와 10개의 메소드를 정의합니다. ERC-721의 supportsInterfaceERC-165 표준 인터페이스 검출에서 파생되었으며 ERC-165는 ERC-721의 일부분입니다. ERC-721 호환 토큰은 ERC-721 및 ERC-165 인터페이스를 구현한 토큰 컨트랙트입니다.

event Transfer(address indexed _from, address indexed _to, uint256 indexed _tokenId);
event Approval(address indexed _owner, address indexed _approved, uint256 indexed _tokenId);
event ApprovalForAll(address indexed _owner, address indexed _operator, bool _approved);

function balanceOf(address _owner) external view returns (uint256);
function ownerOf(uint256 _tokenId) external view returns (address);
function safeTransferFrom(address _from, address _to, uint256 _tokenId, bytes data) external payable;
function safeTransferFrom(address _from, address _to, uint256 _tokenId) external payable;
function transferFrom(address _from, address _to, uint256 _tokenId) external payable;
function approve(address _approved, uint256 _tokenId) external payable;
function setApprovalForAll(address _operator, bool _approved) external;
function getApproved(uint256 _tokenId) external view returns (address);
function isApprovedForAll(address _owner, address _operator) external view returns (bool);
function supportsInterface(bytes4 interfaceID) external view returns (bool);

Based on above interface, developers may customize tokens by adding new features and logics, and deploy on Klaytn network. 자세한 내용은 공식 ERC-721 스펙을 참조하세요.

이 튜토리얼에서는 카드 타입의 대체 불가능한 토큰, 즉 ERC-721 토큰인 MyERC721Card의 구현체인 MyERC721Card.sol를 구현할 것입니다. 각 MyERC721Card는 이름과 레벨, 가령 레벨 1의 "왕(King)", 레벨 1의 "여왕(Queen)"을 가집니다.

MyERC721Card.sol은 OpenZeppelin의 ERC721 구현체를 기반으로 합니다. 이 튜토리얼에서 코드의 주요 부분은 OpenZeppelin 2.3에서 가져왔습니다.

The rest of this tutorial is organized as follows.

Last updated