本次课程分享涉及一下内容,Ethereum, Solana 和 Tezos 的相关的智能合约,智能合约编译工具和 NFT 的 Mint, 本次课程由于时间有限,我们主要重点放在 Ethereum 的 NFT mint 上面;当然,一旦你学会了怎么在 Ethereum Mint NFT,下面这些比较主流的 EVM 链上你也就会了。
- eth
- bsc
- polygon
- arbitrum
- optimistim
- zksync(已经支持 EVM 的链, 未来应该发展很好哈)
- Teleport(我们内部的链,希望他能成为未来的主流链) 这里只是简单的例举,可能还有一些我认为是垃圾链的也是别人也认为是主流链,关于垃圾币和主流币,每个人心里都有一杆秤,衡量的标准可能是因人而已的。当然,还有一些垃圾链使用了 EVM 的你也会了, 下面举一些例子
- evmos
- etc
- heco
- fantom
- Oasis Paratime 侧链
- Boba
- metis
- avalanche
- moonbeam
- moonriver
- harmony
- xdai
- Aurora 关于 Solana,我们也会去介绍一些他相关的合约,比较主流的 NFT 工具,以及 mint NFT 的代码相关的逻辑。Solana 还是一条不错的链,所以我们这次分享把他也纳入进来了,可以说,这条链未来还是值得期待的。
Tezos 就比较小众一些了,我们这次分享,不会花很多时间去讲他。
关于 NFT 的定义大家可能已经在很多地方看到过了,叫做非同质通证或者半同质化通证。当然,看到这个词对于理解NFT一点帮助都没有,大部分非圈内人士都还是会一头雾水,这是什么玩意。首先,我们需要了解什么是同质化,什么是半同质化, 什么是非同质化。
同质化指每个资产都是相同的,可相互替换且可分割。我们在日常生活中使用到的同质化资产包括美元、比特币以及企业发行的积分;例如:1 比特币,可以分成 10 个 0.1 个比特币。
半同质化和非同质化略有不同。 因为它们是半可替代的,所以它们本身与其他 NFT 不同。 但是,它们的数量可能大于一,可以以交易包的形式转账。
非同质化资产:指每个资产是独一无二的,相互完全独立,不可分割的。比如,一副画就是一种非同质化资产。
非同质化通证是在这个“非同质化”的概念上进一步做了扩展,利用以太坊等区块链网络来代表独一无二的实物或数字资产。NFT的所有权通过公共区块链网络进行验证和追踪,用户可以验证每个NFT的真实性,并追踪溯源。
NFT真正的定义应该是:由原创者在区块链上发行的“真实性证明”,通过加密技术来证明NFT的持有者是官方标的资产的真实所有者。
NFT 目前给我们最直观的感觉就是文子,图片,视频文件,音频文件,这也是他们的表现形式之一,从技术的角度出发,NFT 其实就是带有属性的,通过智能合约的形式写到区块链里面独一无二的文子,图片,视频文件和音频文件,用户可以通过区块链来验证每个NFT的真实性,并追踪溯源。
关于 NFT 的价值,我这里就不多说了,我们这个是一个技术分享,教大家怎么去 mint NFT,而不是教大家炒作 NFT,当然,我也没有这个实力教大家炒 NFT。NFT 有没有价值,想想那些抽象派的画作就可以得出结论。经济形势好的时候,它可以天价, 经济形势不好的时候,可能一个馒头也比它的价值高。 上面说了那么多废话,接下来我们进入正题了。
区块链是一个公共数据库,在网络中的许多计算机之间更新和共享。
“块”是指存储在称为“块”的连续组中的数据和状态。如果您将 ETH 发送给其他人,则需要将交易数据添加到块中才能成功。
“链”是指每个块以加密方式引用其父块的事实。换句话说,块被链接在一起。一个区块中的数据不能在不改变所有后续区块的情况下改变,这需要全网的共识。
网络中的每台计算机都必须就每个新区块和整个链达成一致。这些计算机被称为“节点”。节点确保与区块链交互的每个人都拥有相同的数据。为了完成这种分布式协议,区块链需要一个共识机制。
以太坊目前使用 POW 共识机制。ETH2.0 的信标链共识算法为 POS,这意味着任何想要向链中添加新块的人都必须解决一个需要大量计算能力的难题。解决难题“证明”您已经通过使用计算资源完成了“工作”。这样做被称为挖矿。挖矿通常是蛮力试错,但成功添加区块会获得 ETH 奖励。
新块被广播到网络中的节点,检查和验证,从而为每个人更新区块链的状态。
总而言之,当你向某人发送 ETH 时,交易必须被挖掘并包含在一个新区块中。然后与整个网络共享更新的状态。
Ethereum 是一个加密数字货币的公链区块链网络,由 EVM,共识,密码,数据存储,P2P 网络等模块组成的庞大系统, EVM 状态在整个以太坊网络上的每个人都同意。参与以太坊网络的每个人(每个以太坊节点)都保留了这台计算机状态的副本。此外,任何参与者都可以广播请求这台计算机执行任意计算。每当广播这样的请求时,网络上的其他参与者都会验证、确认并执行(“执行”)计算。此执行导致 EVM 中的状态更改,该状态更改已提交并在整个网络中传播。
计算请求称为事务请求;所有交易的记录和 EVM 的当前状态都存储在区块链上,而区块链又被所有节点存储和同意。
加密机制确保一旦交易被验证为有效并添加到区块链,它们以后就不能被篡改。相同的机制还确保所有交易都在适当的“权限”下签名和执行(除了 Alice 自己之外,没有人应该能够从 Alice 的账户发送数字资产)。
智能合约(英语:Smart contract )是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。
在 Ethereum 上,智能合约可以编译成在 EVM 上执行的字节码,常用的开发语言是 solidity, 一种类 Js 的语言,如果你熟悉 Js,学习 solididy 应该不难
ERC是Ethereum Request for Comments(以太坊征求意见提案)的缩写,代表以太坊已正式化的提案,它是由EIP(Ethereum Improvement Proposals以太坊升级提案)经过以太坊开发团队各种审议和测试后通过的一种提案,即对有用提案进行标准化,从而实现对开发者提供模版帮助以及标准限制
ERC 是 Ethereum Request for Comments 的首字母缩写词。它就像技术文档,定义了适用于希望利用以太坊生态系统的一组开发人员和用户的方法、行为、创新和研究。 您可能想知道谁有权创建和管理 ERC。以太坊的智能合约程序员负责编写与 ERC 相关的文档,以描述每个基于以太坊的代币必须遵守的规则集。他们还经常审查这些文件并对其进行评论以进一步改进。 要轻松理解 ERC,请考虑一个工程任务组,它向开发人员传达技术说明和规则,如果每个人都想利用特定生态系统的好处,他们都需要遵守这些规则。
ERC 代币标准解释了建立在以太坊区块链上的所有 ERC 代币的某些规则。以太坊社区对这套规则进行适当的审查,并根据不断变化的需求进行修改。此外,ERC 标准旨在允许 ERC 代币无缝交互。
ERC-20、ERC-721 和 ERC-1155 是三种流行的 ERC 代币标准或协议,它们在主要行业都有应用。以太坊社区完全认可这些代币标准,它们在具体特性和功能方面有所不同。
在了解令牌标准的确切含义或它的工作原理之前,我们应该首先了解以太坊智能合约标准的要领。以下语句对其进行了定义:
- 智能合约描述了智能合约程序员应该遵守的规则,以利用以太坊网络的潜在利益。
- 这些标准适用于支持智能合约和去中心化应用程序(dApps)开发的区块链。
- 智能合约标准包含代币标准、库主题和格式、名称注册表和相关详细信息。
ERC 代币标准只是智能合约标准的另一个名称。以太坊上的智能合约必须遵守标准或规则,才能实现代币创建、交易处理、支出等基本功能。通过引入改进的 ERC 标准,以太坊释放其生态系统的真正潜力,并赋能更具体的智能合同,有助于网络的发展。
ERC-20 于 2015 年首次提出,两年后的 2017 年最终被整合到以太坊生态系统中。ERC-20 引入了在以太坊区块链上创建可替代代币的代币标准。简而言之,ERC-20 由支持开发相同代币的属性组成。 例如,代表货币的 ERC-20 代币可以像以太坊的原生货币 Ether 一样发挥作用。这意味着 1 个代币将始终等于另一个代币的价值,并且可以相互互换。ERC 20 代币为可替代代币的开发设定了标准,但可替代代币实际上可以代表什么,下面举一些例子: ERC-20 于 2015 年首次提出,两年后的 2017 年最终被整合到以太坊生态系统中。ERC-20 引入了在以太坊区块链上创建可替代代币的代币标准。简而言之,ERC-20 由支持开发相同代币的属性组成。 例如,代表货币的 ERC-20 代币可以像以太坊的原生货币 Ether 一样发挥作用。这意味着 1 个代币将始终等于另一个代币的价值,并且可以相互互换。ERC 20 代币为可替代代币的开发设定了标准,但可替代代币实际上可以代表什么,下面举一些例子:
- 任何在线平台的声誉点。
- 彩票和计划。
- 金融资产,例如公司的股票、股息和股票
- 法定货币,包括美元。
- 金盎司,还有更多……
以太坊需要一个强大的标准来统一整个操作,以支持代币开发并在区块链网络上对其进行监管。这就是 ERC-20 发挥作用的地方。
去中心化世界的开发人员将 ERC-20 代币标准广泛用于不同目的,例如开发与以太坊生态系统中可用的其他产品和服务兼容的可互操作代币应用程序。
- ERC 20 代币是“可替代代币”的另一个名称。
- 可替代性定义了资产或代币交换相同价值资产的能力,比如两张 1 美元的钞票。
- 无论其特性和结构如何,每个 ERC-20 代币都严格等同于相同的值。
- ERC 代币最受欢迎的应用领域是稳定币、治理代币和 ICO。
要了解 ERC-721 标准,您必须首先了解 NFT(不可替代 Token )。
Cryptokitties(广泛使用的不可替代代币)的创始人兼首席技术官 Dieter Shirley 最初提议开发一种新的代币类型来支持 NFT。该提案将于 2018 年晚些时候获得批准。它专门用于 NFT,这意味着按照 ERC-721 规则开发的代币可以代表以太坊区块链上任何数字资产的价值。
有了这个,我们得出一个结论:如果 ERC-20 对于发明新的加密货币至关重要,那么 ERC-721 对于代表某人对这些资产的所有权的数字资产来说是无价的。ERC-721 可以表示以下内容:
- 独一无二的数字艺术作品
- 推文和社交媒体帖子
- 游戏内收藏品
- 游戏角色
- 任何卡通人物和数百万其他 NFT ......
这种特殊类型的 Token 为使用 NFT 的企业带来了惊人的可能性。同样,ERC-721 也为他们带来了挑战,为了应对这些挑战,ERC-721 标准开始发挥作用。
请注意,每个 NFT 都有一个称为 tokenId 的 uint256 变量。因此,对于每个 EBR-721 合约,对合约地址 - uint256 tokenId 必须是唯一的。
此外,dApps 还应该有一个“转换器”来规范 NFT 的输入和输出过程。例如,转换器将 tokenId 视为输入并输出不可替代的令牌,例如僵尸、杀戮、游戏收藏品等的图像。
- ERC-721 代币是不可替代代币 (NFT) 的标准。
- 这些代币不能交换任何同等价值的东西,因为它们是独一无二的。
- 每个 ERC-721 代表各自 NFT 的价值,可能不同。
- ERC-721 代币最受欢迎的应用领域是游戏中的 NFT。
结合 ERC-20 和 ERC-720 的能力,Witek Radomski(Enjin 的 CTO)为以太坊智能合约引入了一个包罗万象的代币标准。它是一个标准接口,支持开发可替代、半可替代、不可替代的代币和其他具有通用智能联系人的配置。 现在,您可以使用单一界面满足所有代币开发需求并解决问题,使 ERC-1155 成为游戏规则改变者。这种独特代币标准的想法是开发一个强大的智能合约接口,代表和管理不同形式的 ERC 代币。 ERC-1155 的另一个优点是它改进了以前 ERC 令牌标准的整体功能,使以太坊生态系统更加高效和可扩展。
- ERC-1155 是一个智能合约接口,代表可替代、半可替代和不可替代的代币。
- ERC-1155 可以执行 ERC-20 和 ERC-720 的功能,甚至可以同时执行两者。
- 每个代币可以根据代币的性质代表不同的价值;可替代的、半可替代的或不可替代的。
- ERC-1155 适用于创建 NFT、可兑换购物券、ICO 等。
ERC20, ERC721 和 ERC1155 都各自有自己的标准接口,这个大家可以去阅读源码实现,这里不再做过多的叙述。
- solidity 合约开发语言, 点击进去可以选择相应的版本学习。
- hardhat,推荐使用 hardhat, 我自己使用的就是 hardhat
- truffle
- remix工具; remix 学习文档
- metamask
- Influra: 一家提供 ETH 开放节点的服务上,当然还有其他很多服务商,例如 alchemy;
- 测试币: 此处看你使用的测试,可以去相应的测试网获取测试,如果使用主网,去交易所买 ETH 就行。
Solana 是一个去中心化的区块链,旨在为全世界提供可扩展、用户友好的应用程序。
Solana 是世界上最快的区块链(每个链都这样说,Toncoin 还把 Solana, ETH2.0 和 它自己做了一个对比,得出的结论是,Toncoin 最牛逼),也是加密领域发展最快的生态系统,拥有数千个项目,涵盖 DeFi、NFT、Web3 等。
Solana 其实每个项目方搞的可能不一样,他不像 ETH 那样由标准的协议,目前 solana 里面做 NFT 比较流行的一个代码库是 metaplex, 基本上快成行业标准了。
Tezos 是一个开源平台,由全球验证者、研究人员和建设者社区支持,旨在解决区块链采用所面临的挑战。通过设计,Tezos 具有长期可升级性、开放参与、协作和智能合约安全性。
Tezos 是一种开创性的权益证明区块链,从一开始就构建为比其工作量证明同类产品需要更少的能源。Tezos 开发人员是一个优先考虑可持续性和长期功能而不是表面功能的社区的一部分。
Tezos 旨在通过社区主导的链上治理来发展。开发人员通过提议和投票改变协议的任何方面,包括共识机制,来控制区块链的未来。这可以实现无缝升级并避免对硬分叉的需求。
Tezos 提供了高水平的安全性,甚至能够托管最关键的金融应用程序,这要归功于其深思熟虑和细致的基础设计。以函数式编程为核心,Tezos 促进了智能合约的整体代码正确性、类型安全和形式验证。
Tezos 智能合约是用 Michelson 编写的,这是一种低级堆栈语言。我们建议您使用可编译为 Michelson 的高级语言之一开发您的合约:SmartPy、Ligo 和 Archetype。这些语言支持 Tezos 的所有功能,因此请选择最符合您偏好的语言。