如何使用Alchemy开发NFT智能合约(ERC721)

这篇具有很好参考价值的文章主要介绍了如何使用Alchemy开发NFT智能合约(ERC721)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

本教程翻译自官网:[https://docs.alchemy.com/docs](https://docs.alchemy.com/docs)。

对部分内容进行了修改。教程中所有实例经过本人实践,代码可见:https://github.com/ChuXiaoYi/web3Study

使用Solidity开发智能合约并在区块链上部署可能一开始听起来有些吓人:Solidity、安全性、gas优化、开发环境和gas费用,这些只是你需要了解的一些事情,才能让你的代码托管在区块链上。不用担心,我们来帮你梳理一下。

不过,幸运的是,在过去几个月中,已经发布了许多工具,让开发人员可以更轻松地进行智能合约开发工作。

像OpenZeppelin Wizard这样的工具,为开发人员提供了点击和编写功能,可以在短时间内创建可组合和安全的智能合约,再加上Web3开发人员工具Alchemy的支持,让编写和部署区块链上的代码的体验变得比以往任何时候都更容易、更快速、更可靠。

在本教程中,您将学习如何使用Alchemy、OpenZeppelin、Remix和Ethereum Goerli开发和部署ERC721(NFT)智能合约。

更具体地说,您将学习:

  • 如何使用OpenZeppelin和Remix编写和修改智能合约
  • 使用 https://goerlifaucet.com/获取免费的Goerli ETH
  • 将其部署在Ethereum Goerli测试网络区块链上以节省gas费用
  • 使用Filebase在IPFS上托管NFT令牌元数据。
  • 铸造NFT并在OpenSea上可视化。

您也可以跟随视频教程:

让我们开始创建智能合约。

如前所述,在本教程中,您将使用OpenZeppelin向导创建智能合约,有两个主要原因:

  • 它是安全的。
  • 它提供标准的智能合约。

当涉及编写智能合约时,安全性至关重要。有许多智能合约漏洞的例子,由于安全性不佳而导致恶意行为者窃取了数亿美元。

你不想在部署到区块链上后有人窃取你所有宝贵的加密货币或NFT吧?

OpenZeppelin服务于此目的,是最大的智能合约标准维护者之一(ERC20、ERC721等),允许开发人员使用经过全面审核的代码来开发可靠的合约。

要开发我们的ERC721 NFT智能合约,您需要做的第一件事是进入Open Zeppelin智能合约向导页面。

进入页面后,您将看到以下编辑器:

https://files.readme.io/9e820fe-erc721.png

点击左上角的ERC721按钮,选择要使用的ERC标准类型和要编写的合约类型:

https://files.readme.io/828ee6a-Erc721_2.png

现在您已经选择了合约标准,在左侧菜单中应该会看到一些选项:

让我们从选择代币的名称和符号开始。单击文本框中的“MyToken”,给它命名,然后用同样的方式设置符号,并将基础URI字段留空(代币名称将被OpenSea和Rarible用作集合名称)。

https://files.readme.io/7c6e435-Alh_set.png

现在您需要选择要集成到我们的智能合约中的功能,在“设置”部分之后,您将找到“功能”部分,在那里您将能够选择要包括在您的智能合约中的不同模块。

https://files.readme.io/acaa48a-Miint.png

在这种情况下,您将选择以下集成:

  • Mintable将创建一个仅特权账户可调用的铸造功能
  • Auto Increment IDs将自动为您的NFT分配递增的ID
  • Enumerable将为您提供访问链上代币枚举和“totalSupply”等函数的功能,这些功能在默认的ERC721集成URI存储中不存在,以将元数据和图像与您的每个NFT相关联
  • URI Storage以能够将URI与我们的NFT相关联
https://files.readme.io/d4a7d1d-Screenshot_2022-05-01_at_17.20.48.png

为了本教程的目的,我们建议您不要勾选以下模块,以确保我们的NFT不受到任何类型的Tokenomic影响:

  • 可销毁的 - 用于销毁代币
  • 可暂停的 - 用于暂停代币转移、销售等
  • 投票 - 提供类似于代表和投票的治理功能

如果您想了解更多关于这些模块的信息,请查看官方OpenZeppelin ERC721标准文档。

现在,您已经选择了所需的功能,OpenZeppelin向导将填充智能合约的代码,它应该如下所示:

// SPDX-License-Identifier: MIT
pragma solidity ^0.8.4;

import "@openzeppelin/contracts/token/ERC721/ERC721.sol";
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol";
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol";
import "@openzeppelin/contracts/access/Ownable.sol";

contract Alchemy is ERC721, ERC721Enumerable, ERC721URIStorage, Ownable {
    constructor() ERC721("Alchemy", "ALC") {}

    function safeMint(address to, uint256 tokenId, string memory uri)
        public
        onlyOwner
    {
        _safeMint(to, tokenId);
        _setTokenURI(tokenId, uri);
    }

    // The following functions are overrides required by Solidity.

    function _beforeTokenTransfer(address from, address to, uint256 tokenId)
        internal
        override(ERC721, ERC721Enumerable)
    {
        super._beforeTokenTransfer(from, to, tokenId);
    }

    function _burn(uint256 tokenId) internal override(ERC721, ERC721URIStorage) {
        super._burn(tokenId);
    }

    function tokenURI(uint256 tokenId)
        public
        view
        override(ERC721, ERC721URIStorage)
        returns (string memory)
    {
        return super.tokenURI(tokenId);
    }

    function supportsInterface(bytes4 interfaceId)
        public
        view
        override(ERC721, ERC721Enumerable)
        returns (bool)
    {
        return super.supportsInterface(interfaceId);
    }
}

是时候将我们的代码复制并带到 Remix IDE 上进行修改,并在区块链上部署它了。

现在您已经拥有了ERC721智能合约,让我们在Goerli Testnet上修改并部署它。为此,您将使用Remix IDE,这是一个专门为Solidity智能合约开发而设计的免费Web集成开发环境。

首先,正如您可能已经注意到的那样,在OpenZeppelin Wizard编辑器的顶部,有一个“在Remix中打开”的按钮:

https://files.readme.io/108c79e-Remix.png

点击它将在浏览器的新标签页中打开 REMIX IDE。

从合同的顶部开始,有一个“SPDX-License-Identifier”,它指定了您的代码将发布的许可证类型 - 在Web3应用程序中保持代码开源是一个好习惯,因为它将确保可信度。

// SPDX-License-Identifier: MIT

然后有 pragma - 编译器的版本,您将使用它来编译智能合约代码。小的 “^” 符号告诉编译器,0.8.0 到 0.8.9 之间的每个版本都适合编译我们的代码。

pragma solidity ^0.8.4;

然后我们导入一堆库并初始化智能合约。

import "@openzeppelin/contracts/token/ERC721/ERC721.sol";
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721Enumerable.sol";
import "@openzeppelin/contracts/token/ERC721/extensions/ERC721URIStorage.sol";
import "@openzeppelin/contracts/access/Ownable.sol";
import "@openzeppelin/contracts/utils/Counters.sol";

然后我们初始化合约,继承我们从OpenZeppelin代码库中导入的所有标准:

contract Alchemy is ERC721, ERC721Enumerable, ERC721URIStorage, Ownable {...}

正如您所注意到的,onlyOwner修饰符。

function safeMint(address to, string memory uri) public {
        uint256 tokenId = _tokenIdCounter.current();
        _tokenIdCounter.increment();
        _safeMint(to, tokenId);
        _setTokenURI(tokenId, uri);
    }

你也可以从合约声明 "Ownable" 和库导入中删除它

import "@openzeppelin/contracts/access/Ownable.sol";

现在每个人都可以铸造我们的NFT,你需要避免其他人铸造的NFT数量超过我们收藏中的最大数量。为此,让我们指定可铸造的NFT的最大数量。

假设用户想要铸造总共10,000个NFT。为此,让我们创建一个新的uint256变量,称其为MAX_SUPPLY,并将其赋值为10,000。

Counters.Counter private _tokenIdCounter;
    uint256 MAX_SUPPLY = 100000;

    constructor() ERC721("Alchemy", "ALCH") {}

接下来,让我们进入safeMint函数并在第18行添加一个require语句:

require(_tokenIdCounter.current() <= MAX_SUPPLY, "I'm sorry we reached the cap");

让我们花点时间更好地了解Solidity中的“require”语句。

您可以在官方文档中阅读有关Solidity “require”语句的更多信息。

现在,您已经限制了NFT的最大供应量,是时候在Goerli测试网络上编译智能合约并部署它了。为此,您需要在Alchemy.com上创建一个免费帐户,将其添加为Metamask的节点提供程序,并获取一些免费的Goerli ETH。

首先,让我们导航到alchemy.com,单击“登录”并创建一个新帐户:

https://files.readme.io/56d3600-web3_eco.png

选择以太坊生态系统:

https://files.readme.io/7719099-ether_eco.png

给您的应用程序和团队取一个名称,选择Goerli网络,然后点击创建应用程序:

*Create App*

Create App

完成流程后,我们将被重定向到仪表板页面。点击您选择的应用程序名称,“test”在这种情况下,点击右上角的“查看密钥”按钮,然后复制HTTP URL:

*Your Application Details*

Your Application Details

接下来,您需要将Alchemy添加到Metamask作为Goerli RPC提供程序。如果您尚未安装Metamask,请确保按照此指南将其添加到您的浏览器并创建一个新钱包。

一旦安装Metamask,点击网络下拉菜单,然后点击“添加网络”!

https://files.readme.io/af70d3f-Screen_Shot_2022-09-22_at_1.28.09_PM.png

您将被重定向到以下页面,在该页面上您需要填写Goerli网络和RPC URL信息。

*Fill in the Goerli Network and RPC Url*

Fill in the Goerli Network and RPC Url

在表格中添加以下信息:

  • Network name:Alchemy Goerli
  • New RPC URL: Goerli Alchemy应用程序的HTTP URL
  • Chain ID:5
  • Currency Symbol:GoerliETH
  • Block Explorer:    https://goerli.etherscan.io

太棒了,你使用Alchemy将Goerli添加到了Metamask!🎉

现在是时候在Goerli上部署我们的智能合约了,但首先,你需要获得一些Goerli测试ETH。

获取Goerli测试ETH非常简单,只需前往 goerlifaucet.com,将钱包地址复制到文本栏中,然后点击“发送ETH给我”:

https://files.readme.io/f3d2940-goe.png

在10-20秒后,您将在Metamask钱包中看到Goerli ETH。

您每24小时可以无需登录获得高达0.1 ETH,或者使用Alchemy账户可获得0.5 ETH。

现在您已经获得了测试ETH,是时候在区块链上编译和部署我们的NFT智能合约了。

回到Remix,让我们点击页面左侧的编译器菜单,然后点击蓝色的“编译”按钮:

https://files.readme.io/c0c058f-solid_compiler.png

然后点击“部署和运行交易”菜单,点击环境下拉菜单,并选择“注入Web3”:

确保Metamask钱包在Alchemy Goerli网络上,从合同下拉菜单中选择NFT智能合约,然后点击部署。

https://files.readme.io/e249393-dep.png

一个 Metamask 弹出窗口将出现,点击 "sign",然后继续支付燃气费。

如果一切按预期工作,10 秒后你应该可以在 "已部署的合约" 下看到合约列表:

https://files.readme.io/6630f89-deployed_contracts.png

现在智能合约已经部署到Goerli测试网,是时候铸造我们的NFT了,但首先需要在IPFS上创建并上传元数据,让我们了解一下“元数据”这个术语的含义。

https://files.readme.io/8a5f1ab-octopus.png

为了使OpenSea拉取ERC721代币的离线元数据,合约需要返回指向托管元数据的URI。为了找到这个URI,OpenSea、Rarible和其他流行的市场将使用ERC721Uristorage标准中包含的tokenURI方法。

ERC721中的tokenURI函数应返回HTTP或IPFS URL,例如ipfs://bafkreig4rdq3nvyg2yra5x363gdo4xtbcfjlhshw63we7vtlldyyvwagbq。当查询时,此URL应返回包含代币元数据的JSON blob数据。

您可以在官方OpenSea文档中阅读有关元数据标准的更多信息。

根据OpenSea文档,NFT元数据应存储在.json文件中,并按以下结构进行组织:

{   "description": "YOUR DESCRIPTION",  "external_url": "YOUR URL",  "image": "IMAGE URL",  "name": "TITLE",   "attributes": [    {      "trait_type": "Base",       "value": "Starfish"    },     {      "trait_type": "Eyes",       "value": "Big"    },     {      "trait_type": "Mouth",       "value": "Surprised"    },     {      "trait_type": "Level",       "value": 5    },     {      "trait_type": "Stamina",       "value": 1.4    },     {      "trait_type": "Personality",       "value": "Sad"    },     {      "display_type": "boost_number",       "trait_type": "Aqua Power",       "value": 40    },     {      "display_type": "boost_percentage",       "trait_type": "Stamina Increase",       "value": 10    },     {      "display_type": "number",       "trait_type": "Generation",       "value": 2    }]  }

这里是每个属性存储的简要说明:

属性说明
image该物品图片的 URL。可以是任何类型的图片(包括 SVG,OpenSea 会将其缓存为 PNG),可以是 IPFS URL 或路径。建议使用 350 x 350 的图片。
image_data如果您想要动态生成图片,则可以使用原始的 SVG 图片数据(不建议使用)。只有在不包含 image 参数时才使用此选项。
external_url该链接将出现在 OpenSea 网站上该资产图片下方,用户可以通过该链接离开 OpenSea,在您的网站上查看该资产。
description该物品的人类可读描述。支持 Markdown。
name该物品的名称。
attributes这些是该物品的属性,将出现在 OpenSea 网站上对该物品的页面上。(见下文)
background_color该物品在 OpenSea 上的背景颜色。必须是六位数的十六进制码,不带前导符号。
animation_url一个指向该物品多媒体附件的 URL。支持的文件扩展名有 GLTF、GLB、WEBM、MP4、M4V、OGV、OGG 和仅音频的扩展名 MP3、WAV、OGA。animation_url 还支持 HTML 页面,允许我们使用 JavaScript 画布、WebGL 等构建丰富的体验和交互式 NFT。现在支持 HTML 页面内的脚本和相对路径。但是,不支持浏览器扩展访问。
youtube_url一个指向 YouTube 视频的 URL。

现在我们已经简要了解了令牌元数据中将包含什么内容,让我们学习如何创建它并将其存储在IPFS上。

首先,前往 [filebase.com](https://filebase.com/) 并创建一个新账户。

登录后,点击左侧菜单中的桶按钮,然后创建一个新桶:

https://files.readme.io/73f3bad-filebase.png

进入存储桶,点击 上传按钮,上传你想用于 NFT 的图片,我会使用以下图片。

上传后,点击它并复制 IPFS 网关 URL:

https://files.readme.io/5bd8524-ipfs.png

使用任何文本编辑器,粘贴以下JSON代码:

{   "description": "This NFT proves I've created and deployed my first ERC20 smart contract on Goerli with Alchemy Road to Web3",  "external_url": "Alchemy.com/?a=roadtoweb3weekone",  "image": "https://ipfs.filebase.io/ipfs/bafybeihyvhgbcov2nmvbnveunoodokme5eb42uekrqowxdennt2qyeculm",  "name": "A cool NFT",   "attributes": [    {      "trait_type": "Base",       "value": "Starfish"    },     {      "trait_type": "Eyes",       "value": "Big"    },     {      "trait_type": "Mouth",       "value": "Surprised"    },     {      "trait_type": "Level",       "value": 5    },     {      "trait_type": "Stamina",       "value": 1.4    },     {      "trait_type": "Personality",       "value": "Sad"    },     {      "display_type": "boost_number",       "trait_type": "Aqua Power",       "value": 40    },     {      "display_type": "boost_percentage",       "trait_type": "Stamina Increase",       "value": 10    },     {      "display_type": "number",       "trait_type": "Generation",       "value": 2    }]  }

并将文件另存为“metadata.json”。返回Filebase,将“metadata.json”文件上传到与我们上传图片相同的存储桶中。

https://files.readme.io/6ecc402-metadata.png

最后,点击CID并复制它,在下一部分中我们需要它来构建令牌URI以便铸造NFT:

如何发NFT智能合约,使用Alchemy开发NFT智能合约
如何发NFT智能合约,使用Alchemy开发NFT智能合约

回到Remix,在“Deploy & Run Transactions”菜单下,进入“deployed contracts”,然后点击刚刚部署的合约,在打开的列表中,你会看到智能合约中包含的所有方法:

如何发NFT智能合约,使用Alchemy开发NFT智能合约
如何发NFT智能合约,使用Alchemy开发NFT智能合约

蓝色方法是从区块链中学习的方法。

单击safeMint方法下拉图标,粘贴您的地址和以下字符串到uri字段中:

ipfs://\\<your\\_metadata\\_cid>

单击转账将创建一个Metamask弹出窗口,提示您支付燃气费用。

点击“签名”并继续铸造您的第一个NFT!

等待几秒钟,为确保铸造成功,请将您的地址复制并粘贴到balanceOf方法输入中,并运行它 - 它应该显示您拥有1个NFT。

对于tokenUri方法,请使用“0”作为id参数进行相同操作,它应该显示您的tokenURI。

太棒了!您刚刚铸造了您的第一个NFT!🎉

现在是时候转移到OpenSea,检查元数据是否开始读取了。

前往 testnets.opensea.io,使用您的Metamask钱包登录。然后点击您的个人资料图片,您应该会看到您新铸造的NFT。如果图片还没有显示出来,请点击它,然后点击“刷新元数据”按钮。

https://files.readme.io/3256828-testnet.png

有时候OpenSea很难识别测试网的元数据 - 可能需要长达6个小时才能看到。一段时间后,您的NFT应该会像这样显示:(https://testnets.opensea.io/assets/mumbai/0x5a411430964664412e69cff1134759f6bb57c5d7/1)。

https://files.readme.io/b36cf81-erc_testnet.png

恭喜你成功地创建、修改并部署了你的第一个智能合约。铸造了你的第一个NFT并将你的图像发布到了IPFS上!🔥

下一步呢?为什么不修改你的智能合约,让用户只能铸造一定数量的NFT呢?每个用户只能铸造5个就足够了,否则有人可能会开始铸造成千上万的NFT!

为了做到这一点,请看一下映射类型,这里有一个神奇的指南,可以帮助你完成。文章来源地址https://www.toymoban.com/news/detail-455487.html

到了这里,关于如何使用Alchemy开发NFT智能合约(ERC721)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 创建你自己的ERC-721代币:一个简单的以太坊游戏智能合约模板

    区块链游戏正在成为一种新兴的游戏形式,其中代币化的游戏资产成为了一个重要的组成部分。今天,我们将介绍一个简单的ERC-721智能合约模板,这个模板可以帮助你在以太坊区块链上创建你自己的ERC-721代币,让你的游戏更有趣。 源码下载 ERC-721是一种免费的开放标准,它

    2024年02月07日
    浏览(58)
  • 从零学习NFT(ERC721)

    文章大纲 什么是NFT. NFT有什么价值 市面上有什么NFT交易市场 如何实现自己的NFT(智能合约ERC721) NFT(Non-FungibleToken,非同质化数字权益证明),每个NFT都是唯一不可分割,不可篡改,也不能互相替代的, 因此NFT与虚拟货币等同质化代币存在本质不同,有数字商品的实际价值做支

    2024年02月15日
    浏览(41)
  • Solidity合约标准----ERC721

    非同质化token,它依赖于ERC-165 参照官方提供的案例,直接部署到remix,自动下载依赖 https://docs.openzeppelin.com/contracts/4.x/erc721 部署成功后拥有以下功能 1. 设置待测试的4个账户 2. 铸造NFT 3. 查询NFT数量 4. 依据tokenid查询NFT属主 5.部分NFT委托授权第三者 6.查询NFT是否已被授权 7.由第

    2024年02月02日
    浏览(37)
  • 以太坊区块链ERC-721协议的实现(NFT代币标准)

    ERC-721是以太坊区块链上用于NFT(非同质化代币)的一个标准,是一种其他开发人员都遵守的模板或者格式,用于创建代表数字资产的独特代币,并且每个ERC-721代币都是独一无二的。使用统一的标准可以使合约代码变得更简单,复用性更强。ERC-721的出现促进了NFT的创建,并在

    2024年02月04日
    浏览(55)
  • 以太坊数字资产的发行和流通:以太坊上的数字资产定义、ERC 20代币合约标准、ERC 20标准接口、ERC 721代币合约标准、

    以太坊设计的目标就是让各种数字资产能以智能合约的形式运行在以太坊虚拟机上。目前,众多智能合约中最广泛应用的是代币合约(Token Contract)。是负责管理账户以及其拥有的代币的智能合约,实质可以理解为一张账户地址和对应账户代币余额的映射表。 即:代币可以被

    2023年04月11日
    浏览(54)
  • 区块链java开发智能合约nf(部署第一个NFT智能合约)

    手把手教你区块链java开发智能合约nft-第二篇(部署第一个NFT智能合约) 刚搞区块链开发真的是太累了,自己摸石头过河,动不动就报错,网上搜索错误,一律看不出什么问题,或者报错的信息太少,问同事同事不鸟,问领导,领导也烦,无奈,对于英文不好的我,只能被迫

    2024年02月12日
    浏览(57)
  • 智能合约NFT代币系统的开发:构建数字资产生态

    随着区块链技术的迅速发展和数字资产市场的不断壮大,智能合约NFT(非同质化代币)代币系统成为了吸引眼球的焦点之一。本文将深入探讨智能合约NFT代币系统的开发,以及它如何构建数字资产生态。 引言 数字资产市场的迅速发展和区块链技术的日益成熟,为智能合约N

    2024年04月10日
    浏览(44)
  • 手把手教你区块链java开发智能合约nft-第五篇(铸造第一个NFT)

    初学区块链,那真叫一个痛苦并无助。如果没有人带你的话 今天写的这篇是在前面文章基础上写的,初学区块链的朋友建议先看我前面写的文章 手把手教你区块链java开发智能合约nft-第一篇 手把手教你区块链java开发智能合约nft-第二篇(部署第一个NFT智能合约) 手把手教你

    2023年04月08日
    浏览(94)
  • 手把手教你区块链java开发智能合约nft-第一篇

    刚接触区块链开发,使用java开发,真的是太难了,自己一步步摸索,从新手小白一路碰壁,动不动就报错,去网上搜索对应错误,还真什么都搜索不到,摸索了三四个月,今天终于有了一些进展,今天开始分享出来,希望能帮助到需要的朋友 我作为一个java后端的程序员,不

    2024年01月23日
    浏览(57)
  • 智能合约 之 ERC-20介绍

    ERC20 全称为 Ethereum Request for Comment 20 ,是一种 智能合约标准 ,用于以太坊网络上的代币发行 姊妹篇 - 如何部署ERC20 代币化资产,例如:USDT 是一种以美元为背书的ERC20代币,每个USDT代币都代表着1美元的价值,用户可以随时兑换成等值的美元 去中心化加以所,许多去中心化交

    2024年04月15日
    浏览(33)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包