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

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

在这一部分,我们将使用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以太坊客户端。

  $ npm install -g ethereumjs-testrpc 

ethereumjs-testrpc已被弃用,并已重新命名为ganache-cli,所以请从现在起使用此软件包。

  $ npm install -g ganache-cli 
启动TestRPC
  $ 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} 
 听localhost:8545 

第一个列表是每个帐户的公开地址,第二个列表是与每个帐户关联的私人密钥。

现在,我们将创建一个简单的合同,将公证文件并检查文件是否公证。 然后,我们将首先通过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

  $ solcjs NotarizeDocument.sol --bin 

和下面的命令将创建一个ABI(应用程序二进制接口)。 文件NotarizeDocument_sol_NotarizeDocument.abi将在合同文件夹中创建。

  $ solcjs NotarizeDocument.so l --abi 

现在运行节点控制台并使用TestRpc(http:// localhost:8545,其中testrpc正在运行)实例化Web3。 确保testrpc正在另一个终端中运行。

  $节点 
  > Web3 = require('web3') 
  > provider = new Web3.providers.HttpProvider(“http:// localhost:8545”) 
  > web3 =新的Web3(提供者) 

如果您遇到任何错误,如' 错误:无法找到模块'web3' ',请尝试在本地安装Web3。

  $ npm安装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控制台中创建的块如下所示。 它具有交易散列和合同地址。

 交易:0x0c5467e66b20543117e64dd4e52608488f443e40d38be114a40fccba97ba6793 
 创建合同:0x1f85295bf0773d8c4653fbfae652e205a25b56bb 
 燃气用量:223516 
 区号:1 
 封锁时间: 

现在我们来调用合约的方法

  > contractAddress = deployedContract.address 
  > instance = NotDocContract.at(contractAddress) 
  > instance.notarize(“Hello Romil !!”,{from:account}) 

一旦您调用合约的notarize方法,您可以看到在testrpc控制台中创建的另一个块。

您可以通过调用合约的checkDocument方法来检查上面创建的文档。

  > instance.checkDocument(“Hello Romil !!”) 

这将在控制台中返回true 如果你愿意的话,你可以在这个合同中玩弄同时使用Truffle和TestRPC部署同样的合同。

使用Truffle框架和TestRPC进行部署

现在我们将通过Truffle和TestRPC部署相同的合同。 首先,我们需要安装松露。 让我们在全球安装松露。

  $ npm install -g松露 

在相同的终端窗口中,转到项目/文件夹'EthereumDapp',您有合同并在命令下运行。

  $ truffle unbox webpack 

这将设置完整的项目。 你可以看到更多的合同是合同文件夹下的生成。 在迁移文件夹下也会创建1_initial_migration.js和2_deploy_contracts.js。

让我们编译所有的合约并迁移来部署它们。

  $ truffle编译 
  $松​​露迁移 

一旦部署了合约,您可以看到在testrpc控制台中创建了块/ s。 请注意与其交互的合同地址。 在这种情况下,它是0xc0a80b11dae06421fe2ad2f5a1554c871f72383d

 利用网络“发展”。 
 正在运行迁移:1_initial_migration.js 
 部署迁移... 
  ... 0xd54733a2db0309e394c9b046a76757efbdc44776fa70bfec823fa46b1e6dccc7 
 迁移:0x361bbd4a761363db35983384aa710f421d7f124e 
 保存成功迁移到网络... 
  ... 0x448aca26f656f27647c3c3bb87d5d9fbd2cf66e732d07a883b02314946974c42 
 保存工件... 
 正在运行迁移:2_deploy_contracts.js 
 部署NotarizeDocument ... 
  ... 0x4d3f945d9d9160d3684a5ba204d0ed8571f865ec06496ad574b77a9923edabc5 
  NotarizeDocument:0xc0a80b11dae06421fe2ad2f5a1554c871f72383d 
 保存成功迁移到网络... 
  ... 0xf4d930ec9171e325bfb19631ff742268edba1e7af8011f52944fd06cdef45077 
 保存工件... 

通常松露将合同部署到由testrpc提供的第一个账户。 要与合同进行交互,请转到松露控制台并逐个键入以下命令,并在另一个窗口中继续检查testrpc控制台。

  $松​​露控制台 
 松露(开发)>帐户= web3.eth.accounts [0] 
 松露(开发)> contractAddress = NotarizeDocument.address 
 松露(开发)>实例= NotarizeDocument.at(contractAddress) 

当你得到实例时,让我们调用NotarizeDocument合同的第一个方法,它是公证并传递一些字符串值。

 松露(开发)> instance.notarize(“Hello Romil !!”,{from:account}) 

只要在松露控制台中执行此操作,您可以看到在testrpc控制台中创建的另一个块以及松露控制台中的下方。

  {tx:'0xd81ac2e71a97e457e814042a3593d7a07795c0839fc663107dfb4c47af45ec6d', 
 收据: 
  {transactionHash:'0xd81ac2e71a97e457e814042a3593d7a07795c0839fc663107dfb4c47af45ec6d', 
  transactionIndex:0, 
  blockHash:'0x24bdfb6252d25e1014766eb4fa49e082066fa79213024d6015b84fbc01b70c1d', 
  blockNumber:5, 
  gasUsed:44501, 
 累计使用天数:44501, 
  contractAddress: null 
 日志:[], 
 状态:1}, 
 日志:[]} 

要检查是否创建了此文档,请调用合同的checkDocument方法。

 松露(开发)> instance.checkDocument(“Hello Romil !!”) 

这将在控制台中返回true

现在是你玩这个合同的时候了


https://medium.com/@itsromiljain/get-started-with-building-ethereum-dapps-and-smart-contracts-d86b9f7bd1c

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值