在第一部分中,我们讨论了以太坊,智能合约,EVM和以太坊系统的主要组件。
![](https://img.laitimes.com/img/_0nNw4CM6IyYiwiM6ICdiwiInVGcq5SQtVEduBVaQZXTt4UawkEeOdUU2MnZqEzLcBDM2EzLchXYt9CXt92Yu0WdpRWZt5SMtMXZnFWbp1ibkN2Lc9CX6MHc0RHaiojIsJye.jpeg)
复仇
在这一部分,我们将使用Solidity实现一个非常基本的分散式应用程序,并将使用Web3 / Truffle框架在TestRPC网络上进行开发和部署。
入门
我们需要的基本工具 -
- 节点包管理器(npm) - NPM是Node.js包或模块的包管理器。
- Web3 js-web3js是一个库,可让您通过RPC与区块链进行交互。 该库将用于部署智能合约并与其进行交互。
- Solidity - Solidity是实施智能合约的合同导向的高级语言。 它受C ++,Python和JavaScript的影响,旨在针对以太坊虚拟机(EVM)。
- TestRPC - TestRPC是一个基于Node.js的Ethereum客户端,用于测试和开发。 它在本地运行100%,模拟完整的以太坊客户端,但速度要快得多,非常适合测试和开发。
- Truffle / Embark - Truffle / Embark是以太坊的开发环境,测试框架和资产管道。 基本上,它可以帮助您将合同部署到区块链中,为新的合同交换旧合同(称为迁移),并将您的前端连接到已部署的合同
- MetaMask / Mist - MetaMask / Mist是一款以太坊轻客户端和Chrome扩展程序,让用户无需下载整个区块链即可与区块链互动。 换句话说,它允许您在普通的Chrome浏览器中与dApp进行交互。 MetaMask是虚拟客户端,用于在部署在由Mist提供的实际以太坊网络之前测试和模拟合同。
- Visual Studio代码 - Visual Studio代码是一个源代码编辑器。 它支持许多编程语言和一组可以或不可用于给定语言的功能。 它还具有对Solidity的扩展,这将有助于我们使用此IDE编写Smart Contracts。
所以让我们安装我们的工具。 我们将首先安装npm,如果没有的话。 这里是如何安装它的说明。
一旦安装了npm,我们就可以使用它来安装testrpc,这是一个模仿真实以太坊节点的Node.js以太坊客户端。
ethereumjs-testrpc已被弃用,并已重新命名为ganache-cli,所以请从现在起使用此软件包。
启动TestRPC
这将启动客户端并生成10个账户供您使用,每个账户有100个ETH。 你应该看到这样的东西:
EthereumJS TestRPC v4.1.3(ganache-core:1.1.3)
可用的帐户
==================
(0)0x3f999199f5ce31edd9876f3f29361978da1a1252
(1)0x2c80574fda0a4d9a712ca3d31096967a4635e8f6
(2)0x155c3a4d69cd82f1c4a99f4154bf9ecc68fbdc71
(3)0xa0df2d4d0e538fc44e059e8dbae25692d51c74cb
(4)0x94e40829d2ad19509af489e86d56f5c9634f6206
(5)0xa4878a85d6e1fd4cf7e081b1218dbe74bbd11dc1
(6)0x122a3cd1eb876e825bcea40ec7db929ba2f52ff8
(7)0x2dc1ed0a57144c51030ecd3e453ccd961698e373
(8)0xcb86ed11d282401400da299f43c3809d98c5007a
(9)0xa9e232738bb83f58f4a1fd68175f52dcfa2fe4ad
私人钥匙
==================
(0)3e1a4466eadbb368835c5d57126c73ddc251dc490dd68c412d8c0ad76ee13789
(1)0e773bbdeae3b2e3f7030d13cdada12415659b18e634fbd39ff152bad95825d2
(2)9ffa6dcc4fcb563eb9ac57efdf5bd0cb0d22602a4b86daaedf81c756e5d11baf
(3)963efd39e8e9d7dcf18d72d9d4009cbc8ba1fce1fcdb47d98941c19d9813ad9d
(4)f7b741b1f88441c00a2023620d4c512ffa4e1267e24b06e12860331fdfd9cb78
(5)8f057cc01ec22c0ea27eaa7e50ca6857647299987d1dbe445297ac61b8fe42f9
(6)1e654bbb0d761b84bb738e91d6f4674bb76e0d024b8f24a6c8d301d6e45d5fad
(7)3222876792abbe5b8f5606ac9c6c0b1443c15a3dd5a74de661631a4a3f07fdae
(8)4906df7a8c8f8480a4ce8875016e68e03d52009214b0e5dbec0507005a9dbc23
(9)958b8735820c0fdb3ac142687733987d59677e589695ab6a11a866255df50672
高清钱包
==================
助记符:2月超额牧场价格负荷宣布独自峡谷炉令人惊叹的领导阳台
Base HD Path:m / 44'/ 60'/ 0'/ 0 / {account_index}
第一个列表是每个帐户的公开地址,第二个列表是与每个帐户关联的私人密钥。
现在,我们将创建一个简单的合同,将公证文件并检查文件是否公证。 然后,我们将首先通过Web3和TestRPC部署此合同,然后将使用Truffle框架来执行相同的操作,因为Truffle框架提供了一些开箱即用的功能。
使用Web3 js Library和TestRPC进行部署
首先安装web3 js库和solidity编译器
$ npm install -g web3
$ npm install -g solc
让我们创建一个名称为EthereumDapp的文件夹,然后在其中创建一个子文件夹合约 。 现在我们将在合约子文件夹内创建一个智能合约NotarizeDocument.sol 。 从这里获取代码。
首先,我们必须编译这个文件并创建一个二进制(bin)和abi(应用程序二进制接口)
以下命令将在编译后创建一个二进制文件 我们可以看到在合同文件夹中创建的文件NotarizeDocument_sol_NotarizeDocument.bin 。
和下面的命令将创建一个ABI(应用程序二进制接口)。 文件NotarizeDocument_sol_NotarizeDocument.abi将在合同文件夹中创建。
现在运行节点控制台并使用TestRpc(http:// localhost:8545,其中testrpc正在运行)实例化Web3。 确保testrpc正在另一个终端中运行。
$节点
> Web3 = require('web3')
> provider = new Web3.providers.HttpProvider(“http:// localhost:8545”)
> web3 =新的Web3(提供者)
如果您遇到任何错误,如' 错误:无法找到模块'web3' ',请尝试在本地安装Web3。
Web3为您提供解析合同ABI并提供JavaScript API与其交互的可能性。 然后,您只需要字节码就可以将该合同的一个新实例部署到
testrpc
。 请按照下面的命令:
> NotDocABIFile = fs.readFileSync('NotarizeDocument_sol_NotarizeDocument.abi')
> NotDocABI = JSON.parse(NotDocABIFile.toString()
一旦你跑上面,你会看到只有两个公共职能的合同 - checkDocument和notarize。
让我们继续下去,
> NotDocBINFile = fs.readFileSync('NotarizeDocument_sol_NotarizeDocument.bin')
> NotDocByteCode = NotDocBINFile.toString()
一旦您有NotDocABI和NotDocByteCode,您现在可以将合同部署到testrpc的第一个帐户。
> account = web3.eth.accounts [0]
> NotDocContract = web3.eth.contract(NotDocABI)
> contractData = {data:NotDocByteCode,from:account,gas:999999}
> deployedContract = NotDocContract.new(contractData)
一旦你部署了契约,你可以看到在testrpc控制台中创建的块如下所示。 它具有交易散列和合同地址。
现在我们来调用合约的方法
> contractAddress = deployedContract.address
> instance = NotDocContract.at(contractAddress)
一旦您调用合约的notarize方法,您可以看到在testrpc控制台中创建的另一个块。
您可以通过调用合约的checkDocument方法来检查上面创建的文档。
这将在控制台中返回true 。 如果你愿意的话,你可以在这个合同中玩弄同时使用Truffle和TestRPC部署同样的合同。
使用Truffle框架和TestRPC进行部署
现在我们将通过Truffle和TestRPC部署相同的合同。 首先,我们需要安装松露。 让我们在全球安装松露。
在相同的终端窗口中,转到项目/文件夹'EthereumDapp',您有合同并在命令下运行。
这将设置完整的项目。 你可以看到更多的合同是合同文件夹下的生成。 在迁移文件夹下也会创建1_initial_migration.js和2_deploy_contracts.js。
让我们编译所有的合约并迁移来部署它们。
$ truffle编译
$松露迁移
一旦部署了合约,您可以看到在testrpc控制台中创建了块/ s。 请注意与其交互的合同地址。 在这种情况下,它是0xc0a80b11dae06421fe2ad2f5a1554c871f72383d
通常松露将合同部署到由testrpc提供的第一个账户。 要与合同进行交互,请转到松露控制台并逐个键入以下命令,并在另一个窗口中继续检查testrpc控制台。
当你得到实例时,让我们调用NotarizeDocument合同的第一个方法,它是公证并传递一些字符串值。
只要在松露控制台中执行此操作,您可以看到在testrpc控制台中创建的另一个块以及松露控制台中的下方。
要检查是否创建了此文档,请调用合同的checkDocument方法。
这将在控制台中返回true 。
现在是你玩这个合同的时候了
https://medium.com/@itsromiljain/get-started-with-building-ethereum-dapps-and-smart-contracts-d86b9f7bd1c