前言

在上篇文章里我们部署了我们的智能合约,现在我们可以使用智能合约的方法来铸造数字藏品了,我们的铸造方法需要两个参数,一个是钱包地址,一个是元数据网址,在正式开始铸造之前,我们需要先把我们的元数据存放到一个网址里,这里可以使用你自己的虚拟服务器来存放元数据文件,但为了以后不管过了多久都可以让网址有效,更推荐你把自己的元数据存放到IPFS(去中心化文件存储系统)上。

警告

本指南仅供学习交流使用,不得用于违法用途,如果侵犯了国家法律,责任自负。

使用IPFS配置元数据

IPFS是一种去中心化协议和对等网络,用于在分布式文件系统中存储和共享数据。
关于ipfs系统的选择有很多种,这里我们使用Pinata,一个方便的IPFS API和工具包,用于存储我们的数字藏品资产和元数据,以确保我们的数字藏品真正去中心化。如果您没有Pinata帐户,请在此处注册一个免费帐户,并完成验证电子邮件的步骤。

注册完成登录帐户后,在导航栏里点击Files,下边会有一个Upload按钮,点击它来上传一个图片,上传完成后,在My Files里会多处一行内容,其中有一列是CID,我们可以通过https://gateway.pinata.cloud/ipfs/,来访问我们刚才上传的图片。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

到这里我们已经上传了一个图片,并且可以通过https://gateway.pinata.cloud/ipfs/来查看。
接下来我们还需要再上传一个文件上去,首先我们先创建它,在我们的项目根目录my-contract下创建文件metadata.json,并复制下边内容,然后粘贴到这个文件。

{
  "attributes": [
    {
      "trait_type": "Type",
      "value": "Eyeglass"
    },
    {
      "trait_type": "Color",
      "value": "Red"
    }
  ],
  "description": "This is the most popular reading glasses",
  "image": "https://gateway.pinata.cloud/ipfs/<CID>",
  "name": "Digital collection"
}

这是一个示例内容,你可以根据自己的喜好和需求添加一些内容,但切记image后边的内容一定要替换为上一个你上传的CID,否则元数据里不会看到你上传的图片。
好了,文件编写好了,接下来像上传一个图片那样,把它上传到Pinata,上传成功后,会显示出CID,比如QmaY8pL2ipmC9eiiZ9y6uFGVbMHkCBvKTJ3Qzfnr1VGRZC,拼接成最终的元数据网址:https://gateway.pinata.cloud/ipfs/QmZkFD3Qas7jnr4qnD4AaPUCdUC2MuoLKzbXbX5kZaHG9u,这个就是我们要铸造的第一个藏品的元数据网址。

编写铸造脚本

为了可以调用合约执行铸造方法,我们需要使用JavaScript来编写一个简单的铸造脚本。
打开我们的项目根目录my-contract,在scripts目录下新建文件service.js,这里我们存放一些我们的工具方法,复制并粘贴如下代码

const { ethers } = require("ethers");
const { getContractAt } = require("@nomiclabs/hardhat-ethers/internal/helpers");

function getEnvVariable(key, defaultValue) {
    if (process.env[key]) {
        return process.env[key];
    }
    if (!defaultValue) {
        throw `${key} 未配置`;
    }
    return defaultValue;
}

function getProvider() {
    return ethers.getDefaultProvider(getEnvVariable("NETWORK", "rinkeby"), {
        alchemy: getEnvVariable("ALCHEMY_KEY"),
    });
}

function getAccount() {
    return new ethers.Wallet(getEnvVariable("PRIVATE_KEY"), getProvider());
}
function getContract(contractName, hre) {
    const account = getAccount();
    return getContractAt(hre, contractName, getEnvVariable("CONTRACT_ADDRESS"), account);
}
module.exports = {
    getEnvVariable,
    getProvider,
    getAccount,
    getContract,
}

其中getEnvVariable用于获取.env文件中的环境变量
getProvider用于获取连接到以太坊区块链网络的连接器
getAccount通过我们设置的PRIVATE_KEY变量,来获取私钥对应的钱包地址
getContract返回一个合约实例,通过实例我们可以调用合约方法,这里还需要设置环境变量CONTRACT_ADDRESS,值为部署成功的合约地址

再在scripts目录下新建个mint.js,这是我们的铸造脚本文件,复制并粘贴下边的代码

const { task } = require("hardhat/config");
const { getContract } = require("./service");

task("mint", "Mints from the NFT contract")
    .addParam("address", "The address to receive a token")
    .addParam("tokenuri", "The metadata to a tokenid")
    .setAction(async function (taskArguments, hre) {
        const contract = await getContract("MyContract", hre);
        const transactionResponse = await contract.mintTo(taskArguments.address, taskArguments.tokenuri,{
            gasLimit: 500_000,
        });
        console.log(`Hash: ${transactionResponse.hash}`);
    });

这里我们使用HardHat的任务系统,通过创建mint(铸造任务)到HardHat,使我们可以直接使用cmd命令的方式去执行铸造任务,使用方式为:npx hardhat mint --address 地址 --tokenuri 网址。
接下来我们还要在HardHat配置文件hardhat.config.js中引入mint.js,命令如下
require("./scripts/mint.js");
添加完这些内容后,hardhat.config.js文件内容如下

/**
 * @type import('hardhat/config').HardhatUserConfig
 */

require('dotenv').config();
require("@nomiclabs/hardhat-ethers");
require("./scripts/mint.js");
const { API_URL, PRIVATE_KEY } = process.env;

module.exports = {
  solidity: "0.8.1",
  defaultNetwork: "rinkeby",
  networks: {
    hardhat: {},
    rinkeby: {
      url: API_URL,
      accounts: [`0x${PRIVATE_KEY}`]
    },
    ethereum: {
      chainId: 1,
      url: API_URL,
      accounts: [`0x${PRIVATE_KEY}`]
    },
  },
}

最后一步,在.env文件中增加ALCHEMY_KEY和CONTRACT_ADDRESS,最终.env文件内容是这样的:

API_URL="https://eth-rinkeby.alchemyapi.io/v2/你的Alchemy私钥"
PRIVATE_KEY="你的钱包私钥"
ALCHEMY_KEY="你的Alchemy私钥"
CONTRACT_ADDRESS="你的智能合约地址"

为了验证mint(铸造藏品)任务已成功添加到HardHat,打开cmd,进入到项目根目录my-contract,执行命令

npx hardhat

在这里插入图片描述

如果看到了mint方法,说明铸造任务添加成功。

执行铸造命令

万事具备,只差东风,执行铸造命令

npx hardhat mint --address 钱包地址 --tokenuri 元数据网址
C:\Users\ThinkPad\my-contract>npx hardhat mint --address 0xd6d41E4F4B8b7ed1F5cBe60fdaC9f5BeAE19647c --tokenuri https://gateway.pinata.cloud/ipfs/QmZkFD3Qas7jnr4qnD4AaPUCdUC2MuoLKzbXbX5kZaHG9u
Hash: 0x2e9872e570426a0fc2f11ad5b1b13c31a8167f6a799662fd4b93c03b452da854

执行命令后,如果像上边那样出来hash值代表方法执行成功,复制hash值到区块浏览器查看铸造的详细信息。
在这里插入图片描述

总结

这篇文章结束后,在一切顺利的情况下,你已经可以铸造自己的数字藏品了,虽然是很简单的藏品,但已经起步了,当然你可能有其它的需求,比如铸造藏品需要支付以太坊,铸造藏品仅限合约创建者,这些都可以通过改变智能合约来实现,也需要你自己去探索更多功能。

捐赠渠道

本教程是由本人自发的项目,如果你要支持我,请通过支付宝发送口令红包,将口令发送到我的邮箱351107490@qq.com,捐赠仅凭个人意愿,感谢支持。

Logo

为所有Web3兴趣爱好者提供学习成长、分享交流、生态实践、资源工具等服务,作为Anome Land原住民可不断优先享受各种福利,共同打造全球最大的Web3 UGC游戏平台。

更多推荐