以太坊智能合约的发展在2018年呈指数级增长,2019年似乎将遵循这一趋势。有些框架,如Truffle,可以帮助我们快速构建和维护智能合约,如果您想让亲自动手体验的话,我将解释如何编译您的智能合约,并使用自己的脚本将其部署到以太坊网络。
注意:我将使用简单的智能合约,因为本文的目的只是展示如何编译和部署脚本。
项目具有以下结构:
文件夹合同包含我们的智能合约。对于这篇文章,我们将使用两个简单的智能合约:
MyContractA.sol
MyContractA.sol
如您所见,我们有两个文件,其中一个包含两个智能合约,证明我们可以拥有任意数量的智能合约。
脚本编译
现在,一旦我们有了初始项目结构和智能合约,就可以开始构建编译脚本了。
动态 | ETC预计于7月1日进行Atlantis硬分叉:据cryptoninjas报道,ETC Labs今日宣布将进行Atlantis硬分叉升级,将在ETC上采用以太坊的Byzantium协议。Atlantis目前已在测试网实施,将于区块高度8343000在主网实施,目前预计为7月1日。Atlantis的目标是提高ETC的功能性和稳定性。[2019/6/4]
该脚本的目的是为每个合约生成一个JSON,每个JSON都包含已编译的合同信息。这些JSON将存储在名为build/的输出路径中
构建脚本的步骤如下:
创建构建/目录。
获取我们的合同来源。
编译合同并将输出写入文件。
第1步-创建build/文件夹。
动态 | ETC或推迟Atlantis硬分叉:据coindesk报道,ETC(Ethereum Classic)的开源开发团队周四未能就是否推进即将推出的系统范围的代码升级达成共识,升级计划恢复到了起草阶段。据悉,ETC开发人员自2月以来一直在考虑将一系列共10个提案整合到协议中,该升级被称为“Atlantis”。在今天的电话会议中,一些开发人员对是否应将提案EIP 170纳入Atlantis升级表示犹豫。开发人员Anthony Lusardi表示,这些规则可以简单地应用于事务验证而不是区块验证,使其成为一个软分叉而不是硬分叉。据报道,开发人员今日尚未就Atlantis升级的时间表或内容作出任何决定。[2019/5/31]
这一步是最简单的,因为我们只需要了解JavaScript的一些基础知识。
现在要将所有文件的来源都放到智能合约文件夹中。在这一步中,只需要JavaScript就不需要以太坊概念,但还是有点复杂。
动态 | Banco Do Brasil获得法院授权关闭Atlas Quantum账户:据bitcoinnews消息,巴西法院已经裁定支持巴西第二大银行Banco do Brasil,并授权他们关闭“缺乏监管”的加密货币公司Atlas Quantum的账户。法官Gustavo Coube de Carvalho还下令Atlas支付5千巴西雷亚尔的行政费用,但加密公司已决定对该决定提出上诉。[2019/2/25]
对于contracts文件夹中的每个文件,我们在sources对象中添加一个新字段,其中键是文件名,值是.sol文件的内容。
第3步-编译并写入输出
现在我们已经有了输出文件夹和智能合约的内容,是时候编译它们了。
首先,我们必须定义一个对象,该对象将作为Solidity编译器的信息输入。
动态 | Cardano基金会宣布加大对区块链安全研究的支持:Cardano基金会宣布将进一步支持非洲、美洲、亚洲和欧洲研究区块链技术的学术项目。其生态系统合作伙伴Input Output HK(IOHK)和EMURGO将支持各种旨在推动数字货币和区块链技术发展的计划。该支持将有助于促进有关整个区块链行业的安全性和脆弱性的研究。[2019/8/15]
language:我们智能合约的编程语言,目前是使用Solidity,但你也可以选择其他编程语言。
sources:我们合同的内容。
settings:此选项告诉编译器我们想要生成哪些输出字段。对于此示例,我选择sources中的所有文件生成abi和evm.bytecode。这两条信息是部署阶段所必需的。
一旦我们有了编译器的配置对象,我们就可以执行它了。
第一行获取一个包含我们编译的脚本的对象。两个for循环允许我们在不同的JSON文件中存储单个.sol文件中的智能合约。
最后一步是把这三部分连接在一起
这样我们就完成了编译脚本。如果我们运行它,项目结构应该如下所示:
我们已经gitignoredbuild文件夹,因为没有意义在Git下跟踪它。
现在我们已经编辑了我们的智能合约,是时候将它们部署到区块链上了。
脚本部署
是时候将我们的智能合约部署到以太坊区块链上了。
首先,我们需要两件事来将智能合约部署到区块链:
解锁帐户:由于我们需要使用gas来发送将创建智能合约的交易。
连接到区块链的节点:我们正在向网络发送交易,因此我们需要连接到链上。
关于第一点,我们将使用HDWalletProvider,这个工具允许我们使用助记符十二个单词短语解锁帐户并连接到以太坊节点。但是......节点在哪里?好吧,我们可以做两件事,运行我们自己的以太坊节点或使用Infura。Infura是一项服务,它允许我们连接到以太坊网络,而无需运行我们自己的以太坊节点。所以,我们似乎已经涵盖了两点。
解锁帐户并连接到以太坊节点。
要使用Infura,我们需要在其页面中注册。它将生成我们需要使用其服务的API密钥。
我们将使用Web3JS与区块链进行交互。Web3需要提供程序来连接节点并与节点交互。这个提供程序是HDWalletProvider,我们来配置它和Web3。
HDWalletProvider的第一个参数是我们的12个单词助记词。这个短语允许提供者解锁帐户,第二个参数告诉提供者以太网节点在哪里,在这种情况下我们通过Infura连接。
最后我们在web3中设置了提供者。
通过正确配置web3,我们可以最终部署合同。
首先,我们需要我们编译的脚本。
然后,在第8行中,我们使用Web3API创建智能合约,并将智能合约的接口传递给它。接下来,我们需要创建一个包含智能合约信息的部署事务:
data:合同的字节代码。它以0x开头表示它是十六进制的。
arguments:我们的智能合约构造函数的参数。
创建事务后,我们将其发送到以太坊区块链,以便为节点处理它:
from:签署交易并发送的帐户。在第4行中,我们获得了HDWalletProvider生成和解锁的帐户以及12个单词短语。
gas:我们想要用于发送交易的最大gas量。
第18行的console.log对于获取部署合同的地址很重要,这样我们将来可以将其用于DAPP、用于其他合同等。
脚本的最后一行告诉提供程序结束与以太坊节点的连接。
如果我们执行脚本,一段时间后,我们将获得如下跟踪:
现在我们可以访问EtherScan并查看我们在区块链中部署的智能合约。
最后,我们已经部署了智能合约,并且每个人都可以访问。我希望这篇文章有所帮助。
郑重声明: 本文版权归原作者所有, 转载文章仅为传播更多信息之目的, 如作者信息标记有误, 请第一时间联系我们修改或删除, 多谢。