首页 > 区块链 > 以太坊Truffle框架搭建一气呵成无坑版教程
挖挖矿区  

以太坊Truffle框架搭建一气呵成无坑版教程

摘要:区块链兄弟区块链兄弟社区,区块链技术专业问答先行者,中国区块链技术爱好者聚集地来源:CSDN原文链接:https://blog.csdn.net/phil_code/article/details/79769247著权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。本文约1600字+,

区块链兄弟社区,区块链技术专业问答先行者,中国区块链技术爱好者聚集地

以太坊Truffle框架搭建一气呵成无坑版教程

来源:CSDN

原文链接:https://blog.csdn.net/phil_code/article/details/79769247

著权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

本文约1600字+,阅读(观看)需要15分钟

Truffle框架搭建的教程网上也有好多,但是随着truffle版本的更新,truffle.js改名truffle-config.js、truffle命令升级、truffle与testrpc端口不一致、浏览器钱包插件等问题,导致原有的教程不再适用,在踩过一个又一个的坑后,打算写一篇无坑版本,让广大初学者可以一气呵成搭建完环境。

安装Node.js

在https://nodejs.org/en/下载安装包,选择LTS版本下载。

以太坊Truffle框架搭建一气呵成无坑版教程

写文章时最新版本是8.11.1,安装后在windows命令cmd窗口,输入node -v,能显示node的版本就成功第一步

ruffle是本地的用来编译、部署智能合约的工具。

在windows命令行窗口输入npm -g install truffle。

以太坊Truffle框架搭建一气呵成无坑版教程

没有报错信息就是成功第二步

安装Ethereum TestR

命令行窗口输入npm install -g ethereumjs-testrpc

以太坊Truffle框架搭建一气呵成无坑版教程

安装后再输入testrpc看是否成功启动,testrpc默认是监听8545端口

以太坊Truffle框架搭建一气呵成无坑版教程

启动Dapp

第三步启动的testrpc窗口不要关闭,新建立开发目录helloworld,打开一个新的命令窗口。进入到helloword目录。

truffle 初始化

输入truffle unbox webpack执行完后,再输入dir看本地有没有下载到新的文件。网上很多老的教程是truffle init webpack命令,但是truffle新的版本不支持,只能是truffle unbox webpack。

编译合约

输入命令truffle compile出现下面的错误,这也是旧的教程的一个坑。

以太坊Truffle框架搭建一气呵成无坑版教程

把helloworld目录的truffle.js改名为truffle-config.js,再执行命令。

以太坊Truffle框架搭建一气呵成无坑版教程

以太坊Truffle框架搭建一气呵成无坑版教程

部署合约

部署智能合约成功的前提就是testrpc已经在运行,输入命令truffle migrate。

以太坊Truffle框架搭建一气呵成无坑版教程

启动服务

输入命令npm run dev.

以太坊Truffle框架搭建一气呵成无坑版教程

打开浏览器,输入 http://localhost:8080/,出现"Couldn't get any accounts! Make sure yourEthereum client is configured correctly."

以太坊Truffle框架搭建一气呵成无坑版教程

原因是chrome浏览器里安装MetaMask-以太坊钱包插件,把插件移除掉或者使用其他浏览器。

以太坊Truffle框架搭建一气呵成无坑版教程

移除插件再打开,提示“There was an error fetching your accounts.”。

以太坊Truffle框架搭建一气呵成无坑版教程

F12打开开发者工具,js代码是请求testrpc的9545端口。

以太坊Truffle框架搭建一气呵成无坑版教程

请求合约的端口9545和testrpc监听端口8545不一致,只要把两者改成一致就行,解决办法以下二选一即可 :

1.修改合约调用代码。helloworld\app\javascripts\app.js,把window.web3 = new Web3(new Web3.providers.HttpProvider("http://127.0.0.1:9545"));的端口号9545改为8545

以太坊Truffle框架搭建一气呵成无坑版教程

2. testrpc监听端口改为8545。

启动testrpc时用命令行 testrpc –p 9545。

truffle部署合约的端口也改为9545,在truffle-config.js把port参数改为9545。

执行truffle compile、truffle migrate、npm run dev重新编译、部署、启动。

合约调用

testrpc控制台上有十个测试地址,复制一个地址在页面转账。

以太坊Truffle框架搭建一气呵成无坑版教程

以太坊Truffle框架搭建一气呵成无坑版教程

文章发布只为分享区块链技术内容,版权归原作者所有,观点仅代表作者本人,绝不代表区块链兄弟赞同其观点或证实其描述。

免责声明
世链财经作为开放的信息发布平台,所有资讯仅代表作者个人观点,与世链财经无关。如文章、图片、音频或视频出现侵权、违规及其他不当言论,请提供相关材料,发送到:2785592653@qq.com。
风险提示:本站所提供的资讯不代表任何投资暗示。投资有风险,入市须谨慎。
世链粉丝群:提供最新热点新闻,空投糖果、红包等福利,微信:msy2134。