天天看点

【译】Getting Started With Ethereum and Building a Basic Dapp — Part 2

在第一部分中,我们讨论了以太坊,智能合约,EVM和以太坊系统的主要组件。

【译】Getting Started With Ethereum and Building a Basic Dapp — Part 2

复仇

在这一部分,我们将使用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

继续阅读