精华内容
下载资源
问答
  • 如果你对于以太坊智能合约开发还没有概念(本文会假设你已经知道这些概念),建议先阅读入门篇。 就先学习任何编程语言...今天我们来一步一步从搭建以太坊智能合约开发环境开始,讲解智能合约的Hello World如何编写。

    最新内容会更新在主站深入浅出区块链社区
    原文链接:智能合约开发环境搭建及Hello World合约

    如果你对于以太坊智能合约开发还没有概念(本文会假设你已经知道这些概念),建议先阅读入门篇
    就先学习任何编程语言一样,入门的第一个程序都是Hello World。今天我们来一步一步从搭建以太坊智能合约开发环境开始,讲解智能合约的Hello World如何编写。

    开发环境搭建

    Solidity安装

    强烈建议新手使用Browser-Solidity来进行开发。
    Browser-Solidity是一个基于浏览器的Solidity,就可以不用安装Solidity,本文的Hello World教程也将基于Browser-Solidity来进行。

    如果你想自己安装请参考Solidity安装指引

    geth 安装

    Mac下安装命令如下:其他平台参考:geth官方安装指引

    brew tap ethereum/ethereum
    brew install ethereum
    

    brew 是 Mac 下的包管理工具,和Ubuntu里的apt-get类似

    安装完以后,就是把geth控制台启动。

    启动环境

    在入门篇讲过,geth是一个以太坊客户端,现在利用geth启动一个以太坊(开发者)网络节点。

    geth --datadir testNet --dev console 2>> test.log
    

    执行命名后,会进入geth控制台,这时光标停在一个向右的箭头处,像这样:

    命令参数说明:
    –dev 启用开发者网络(模式),开发者网络会使用POA共识,默认预分配一个开发者账户并且会自动开启挖矿。
    –datadir 后面的参数是区块数据及秘钥存放目录。
    第一次输入命令后,它会放在当前目录下新建一个testNet目录来存放数据。
    console 进入控制台
    2>> test.log 表示把控制台日志输出到test.log文件

    为了更好的理解,建议新开一个命令行终端,实时显示日志:

    tail -f test.log
    

    准备账户

    部署智能合约需要一个外部账户,我们先来看看分配的开发者账户,在控制台使用以下命令查看账户:

    > eth.accounts
    

    回车后,返回一个账户数组,里面有一个默认账户,如:

    也可以使用personal.listAccounts查看账户,

    再来看一下账户里的余额,使用一下命令:

    > eth.getBalance(eth.accounts[0])
    

    **eth.accounts[0]**表示账户列表第一个账户
    回车后,可以看到大量的余额,如:
    1.15792089237316195423570985008687907853269… e+77

    开发者账户因余额太多,如果用这个账户来部署合约时会无法看到余额变化,为了更好的体验完整的过程,这里选择创建一个新的账户。

    创建账户

    使用以下命令创建账户:

    > personal.newAccount("TinyXiong")
    

    TinyXiong为新账户的密码,回车后,返回一个新账户。

    这时我们查看账户列表:

    > eth.accounts
    

    可以看到账户数组你包含两个账户,新账户在第二个(索引为1)位置。

    现在看看账户的余额:

    > eth.getBalance(eth.accounts[1])
    0
    

    回车后,返回的是0,新账户是0。结果如:

    给新账户转账

    我们知道没有余额的账户是没法部署合约的,那我们就从默认账户转1以太币给新账户,使用以下命令(请使用你自己eth.accounts对应输出的账户):

    eth.sendTransaction({from: '0xb0ebe17ef0e96b5c525709c0a1ede347c66bd391', to: '0xf280facfd60d61f6fd3f88c9dee4fb90d0e11dfc', value: web3.toWei(1, "ether")})
    

    在打开的tail -f test.log日志终端里,可以同时看到挖矿记录
    再次查看新账户余额,可以新账户有1个以太币

    解锁账户

    在部署合约前需要先解锁账户(就像银行转账要输入密码一样),使用以下命令:

    personal.unlockAccount(eth.accounts[1],"TinyXiong");
    

    “TinyXiong” 是之前创建账户时的密码
    解锁成功后,账户就准备完毕啦,接下来就是编写合约代码。

    编写合约代码

    现在我们来开始编写第一个智能合约代码,solidity代码如下:

    pragma solidity ^0.4.18;
    contract hello {
        string greeting;
        
        function hello(string _greeting) public {
            greeting = _greeting;
        }
    
        function say() constant public returns (string) {
            return greeting;
        }
    }
    

    简单解释下,我们定义了一个名为hello的合约,在合约初始化时保存了一个字符串(我们会传入hello world),每次调用say返回字符串。
    把这段代码写(拷贝)到Browser-Solidity,如果没有错误,点击Details获取部署代码,如:

    在弹出的对话框中找到WEB3DEPLOY部分,点拷贝,粘贴到编辑器后,修改初始化字符串为hello world。

    solidity在博文写作时(2017/11/24),版本为0.4.18,solidity发展非常快,solidity版本之间有可能不能兼容,这是你可以在Browser-Solidity的Settings里选择对应的编译器版本。
    Browser-Solidity也不停的更新中,截图可能和你看到的界面不一样。

    部署合约

    Browser-Solidity生成的代码,拷贝到编辑器里修改后的代码如下:

    var _greeting = "Hello World" ;
    var helloContract = web3.eth.contract([{"constant":true,"inputs":[],"name":"say","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_greeting","type":"string"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"}]);
    var hello = helloContract.new(
       _greeting,
       {
         from: web3.eth.accounts[1], 
         data: '0x6060604052341561000f57600080fd5b6040516102b83803806102b8833981016040528080518201919050508060009080519060200190610041929190610048565b50506100ed565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061008957805160ff19168380011785556100b7565b828001600101855582156100b7579182015b828111156100b657825182559160200191906001019061009b565b5b5090506100c491906100c8565b5090565b6100ea91905b808211156100e65760008160009055506001016100ce565b5090565b90565b6101bc806100fc6000396000f300606060405260043610610041576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063954ab4b214610046575b600080fd5b341561005157600080fd5b6100596100d4565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561009957808201518184015260208101905061007e565b50505050905090810190601f1680156100c65780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6100dc61017c565b60008054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156101725780601f1061014757610100808354040283529160200191610172565b820191906000526020600020905b81548152906001019060200180831161015557829003601f168201915b5050505050905090565b6020604051908101604052806000815250905600a165627a7a723058204a5577bb3ad30e02f7a3bdd90eedcc682700d67fc8ed6604d38bb739c0655df90029', 
         gas: '4700000'
       }, function (e, contract){
        console.log(e, contract);
        if (typeof contract.address !== 'undefined') {
             console.log('Contract mined! address: ' + contract.address + ' transactionHash: ' + contract.transactionHash);
        }
     });
    

    第1行:修改字符串为Hello World
    第2行:修改合约变量名
    第3行:修改合约实例变量名,之后可以直接用实例调用函数。
    第6行:修改部署账户为新账户索引,即使用新账户来部署合约。
    第8行:准备付的gas费用,IDE已经帮我们预估好了。
    第9行:设置部署回调函数。

    拷贝会geth控制台里,回车后,看到输出如:

    Contract mined! address: 0x79544078dcd9d560ec3f6eff0af42a9fc84c7d19 transactionHash: 0xe2caab22102e93434888a0b8013a7ae7e804b132e4a8bfd2318356f6cf0480b3
    

    说明合约已经部署成功。

    在打开的tail -f test.log日志终端里,可以同时看到挖矿记录

    现在我们查看下新账户的余额:

    > eth.getBalance(eth.accounts[1])
    

    是不是比之前转账的余额少呀!

    运行合约

    > hello.say()
    "Hello World"
    

    输出Hello World,我们第一个合约Hello World,成功运行了。

    本文会随geth,solidity语言版本升级保持更新,查看本文原始链接:https://learnblockchain.cn/2017/11/24/init-env/

    第一个合约的意义更重要的是体验智能合约开发流程,对于初学者一些可以选择先放弃一些细节,开发流程打通之后,可以增强信心进行下一步的学习。
    有问题就加入深入浅出区块链群一起来交流吧。

    深入浅出区块链 - 系统学习区块链,打造最好的区块链技术博客

    展开全文
  • 今天我们来一步一步从搭建以太坊智能合约开发环境开始,讲解智能合约的Hello World如何编写。 开发环境搭建 Solidity安装 强烈建议新手使用Browser-Solidity来进行开发。 Browser-Solidity是一...
      

    和先学习任何编程语言一样,入门的第一个程序都是Hello World。今天我们来一步一步从搭建以太坊智能合约开发环境开始,讲解智能合约的Hello World如何编写。

    开发环境搭建

    Solidity安装

    强烈建议新手使用Browser-Solidity来进行开发。

    Browser-Solidity是一个基于浏览器的Solidity,就可以不用安装Solidity,本文的Hello World教程也将基于Browser-Solidity来进行。

    如果你想自己安装请google相关资料。

    geth 安装

    Mac下安装命令如下:其他平台参考:geth官方安装指引

    brew 是 Mac 下的包管理工具,和Ubuntu里的apt-get类似

    安装完以后,就是把geth控制台启动。

    启动环境

    在入门篇讲过,geth是一个以太坊客户端,现在利用geth启动一个以太坊(开发者)网络节点。

    执行命名后,会进入geth控制台,这时光标停在一个向右的箭头处,像这样:


    v2-5c6c7e199114eff5ab8d3b5eb1652749_b.jpg


    命令参数说明(更多命令详解可阅读Geth命令用法-参数详解篇):

    –dev 启用开发者网络(模式),开发者网络会使用POA共识,默认预分配一个开发者账户并且会自动开启挖矿。

    –datadir 后面的参数是区块数据及秘钥存放目录。

    第一次输入命令后,它会放在当前目录下新建一个testNet目录来存放数据。

    console 进入控制台

    2>> test.log 表示把控制台日志输出到test.log文件

    为了更好的理解,建议新开一个命令行终端,实时显示日志:

    准备账户

    部署智能合约需要一个外部账户,我们先来看看分配的开发者账户,在控制台使用以下命令查看账户:

    回车后,返回一个账户数组,里面有一个默认账户,如:


    v2-faaae6991ceea637e7107bf794ab3701_b.jpg


    也可以使用personal.listAccounts查看账户,

    再来看一下账户里的余额,使用一下命令:

    eth.accounts[0]表示账户列表第一个账户

    回车后,可以看到大量的余额,如:

    1.15792089237316195423570985008687907853269… e+77

    开发者账户因余额太多,如果用这个账户来部署合约时会无法看到余额变化,为了更好的体验完整的过程,这里选择创建一个新的账户。

    创建账户

    使用以下命令创建账户:

    TinyXiong为新账户的密码,回车后,返回一个新账户。

    这时我们查看账户列表:

    可以看到账户数组你包含两个账户,新账户在第二个(索引为1)位置。

    现在看看账户的余额:

    回车后,返回的是0,新账户是0。结果如:


    v2-7db2bf2448cb4ae979bd28af0c9b3c5f_b.jpg


    给新账户转账

    我们知道没有余额的账户是没法部署合约的,那我们就从默认账户转1以太币给新账户,使用以下命令(请使用你自己eth.accounts对应输出的账户):

    在打开的tail -f test.log日志终端里,可以同时看到挖矿记录

    再次查看新账户余额,可以新账户有1个以太币


    v2-5ca494e12e204ecd99aa4ead79fe8a68_b.jpg


    解锁账户

    在部署合约前需要先解锁账户(就像银行转账要输入密码一样),使用以下命令:

    “TinyXiong” 是之前创建账户时的密码

    解锁成功后,账户就准备完毕啦,接下来就是编写合约代码。

    编写合约代码

    现在我们来开始编写第一个智能合约代码,solidity代码如下:

    简单解释下,我们定义了一个名为hello的合约,在合约初始化时保存了一个字符串(我们会传入hello world),每次调用say返回字符串。

    把这段代码写(拷贝)到Browser-Solidity,如果没有错误,点击Details获取部署代码,如:


    v2-a088d1ed2d6a37566218d577bfabbb4b_b.jpg


    在弹出的对话框中找到WEB3DEPLOY部分,点拷贝,粘贴到编辑器后,修改初始化字符串为hello world。


    v2-7fb8ab4294565ecffa0ca2d895cb3f84_b.jpg


    solidity在博文写作时(2017/11/24),版本为0.4.18,solidity发展非常快,solidity版本之间有可能不能兼容,这是你可以在Browser-Solidity的Settings里选择对应的编译器版本。

    Browser-Solidity也不停的更新中,截图可能和你看到的界面不一样。

    部署合约

    Browser-Solidity生成的代码,拷贝到编辑器里修改后的代码如下:

    第1行:修改字符串为Hello World

    第2行:修改合约变量名

    第3行:修改合约实例变量名,之后可以直接用实例调用函数。

    第6行:修改部署账户为新账户索引,即使用新账户来部署合约。

    第8行:准备付的gas费用,IDE已经帮我们预估好了。

    第9行:设置部署回调函数。

    拷贝回geth控制台里,回车后,看到输出如:

    说明合约已经部署成功。

    在打开的tail -f test.log日志终端里,可以同时看到挖矿记录

    现在我们查看下新账户的余额:

    是不是比之前转账的余额少呀!

    运行合约

    输出Hello World,我们第一个合约Hello World,成功运行了。

    运行截图如下:


    v2-31fc018f81b4a551d76a0ace77089b09_b.jpg


    如果你有疑问欢迎加微信咨询:


    u.wechat.com/MDHWBbNbJR (二维码自动识别)


    也可以关注我的公众号想我提问:


    weixin.qq.com/r/EEzl-dL (二维码自动识别)

    展开全文
  • 智能合约开发环境搭建及 Hello World 合约 如果你对于以太坊智能合约开发还没有概念(本文会假设你已经知道这些概念),建议先阅读入门篇。 就先学习任何编程语言一样,入门的第一个程序都是 Hello World。今天我们...

    智能合约开发环境搭建及 Hello World 合约

    如果你对于以太坊智能合约开发还没有概念(本文会假设你已经知道这些概念),建议先阅读入门篇
    就先学习任何编程语言一样,入门的第一个程序都是 Hello World。今天我们来一步一步从搭建以太坊智能合约开发环境开始,讲解智能合约的 Hello World 如何编写。

    开发环境搭建

    Solidity 安装

    强烈建议新手使用 Remix -Solidity IDE 来进行开发。
    Remix 是一个基于浏览器的 Solidity,就可以不用安装 Solidity,本文的 Hello World 教程也将基于 Remix Solidity IDE 来进行。

    如果你想自己安装请参考 Solidity 安装指引

    更新,开发环境搭建还可以看另一篇文章: 搭建智能合约开发环境 Remix IDE 及使用

    geth 安装

    Mac 下安装命令如下:其他平台参考:geth 官方安装指引

    1
    2
    
    brew tap ethereum/ethereum
    brew install ethereum
    

     

    brew 是 Mac 下的包管理工具,和 Ubuntu 里的 apt-get 类似

    安装完以后,就是把 geth 控制台启动。

    启动环境

    在入门篇讲过,geth 是一个以太坊客户端,现在利用 geth启动一个以太坊(开发者)网络节点。

    1
    
    geth --datadir testNet --dev console 2>> test.log
    

    执行命名后,会进入 geth 控制台,这时光标停在一个向右的箭头处,像这样:
    geth控制台

    命令参数说明(更多命令详解可阅读 Geth 命令用法 - 参数详解篇):
    —dev 启用开发者网络(模式),开发者网络会使用 POA 共识,默认预分配一个开发者账户并且会自动开启挖矿。
    —datadir 后面的参数是区块数据及秘钥存放目录。
    第一次输入命令后,它会放在当前目录下新建一个 testNet 目录来存放数据。
    console 进入控制台
    2>> test.log 表示把控制台日志输出到 test.log 文件

    为了更好的理解,建议新开一个命令行终端,实时显示日志:

    1
    
    tail -f test.log
    

     

    准备账户

    部署智能合约需要一个外部账户,我们先来看看分配的开发者账户,在控制台使用以下命令查看账户:

    1
    
    > eth.accounts
    

     

    回车后,返回一个账户数组,里面有一个默认账户,如:
    返回账户图

    也可以使用 personal.listAccounts 查看账户,

    再来看一下账户里的余额,使用以下命令:

    1
    
    > eth.getBalance(eth.accounts[0])
    

     

    eth.accounts[0] 表示账户列表第一个账户
    回车后,可以看到大量的余额,如:
    1.15792089237316195423570985008687907853269… e+77

    开发者账户因余额太多,如果用这个账户来部署合约时会无法看到余额变化,为了更好的体验完整的过程,这里选择创建一个新的账户。

    创建账户

    使用以下命令创建账户:

    1
    
    > personal.newAccount("TinyXiong")
    

     

    TinyXiong 为新账户的密码,回车后,返回一个新账户。

    这时我们查看账户列表:

    1
    
    > eth.accounts
    

     

    可以看到账户数组你包含两个账户,新账户在第二个(索引为 1)位置。

    现在看看账户的余额:

    1
    2
    
    > eth.getBalance(eth.accounts[1])
    0
    

     

    回车后,返回的是 0,新账户是 0。结果如:
    新账户图

    给新账户转账

    我们知道没有余额的账户是没法部署合约的,那我们就从默认账户转 1 以太币给新账户,使用以下命令(请使用你自己 eth.accounts 对应输出的账户):

    1
    
    eth.sendTransaction({from: '0xb0ebe17ef0e96b5c525709c0a1ede347c66bd391', to: '0xf280facfd60d61f6fd3f88c9dee4fb90d0e11dfc', value: web3.toWei(1, "ether")})
    

     

    在打开的 tail -f test.log 日志终端里,可以同时看到挖矿记录
    再次查看新账户余额,可以新账户有 1 个以太币
    账户余额

    解锁账户

    在部署合约前需要先解锁账户(就像银行转账要输入密码一样),使用以下命令:

    1
    
    personal.unlockAccount(eth.accounts[1],"TinyXiong");
    

     

    “TinyXiong” 是之前创建账户时的密码
    解锁成功后,账户就准备完毕啦,接下来就是编写合约代码。

    编写合约代码

    现在我们来开始编写第一个智能合约代码,solidity 代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    
    pragma solidity ^0.4.18;
    contract hello {
        string greeting;
    
        function hello(string _greeting) public {
            greeting = _greeting;
        }
    
        function say() constant public returns (string) {
            return greeting;
        }
    }
    

    简单解释下,我们定义了一个名为 hello 的合约,在合约初始化时保存了一个字符串(我们会传入 hello world),每次调用 say 返回字符串。
    把这段代码写 (拷贝) 到 Browser-Solidity,如果没有错误,点击 Details 获取部署代码,如:

    在弹出的对话框中找到 WEB3DEPLOY 部分,点拷贝,粘贴到编辑器后,修改初始化字符串为 hello world。

    solidity 在博文写作时(2017/11/24),版本为 0.4.18,solidity 发展非常快,solidity 版本之间有可能不能兼容,这是你可以在 Browser-Solidity 的 Settings 里选择对应的编译器版本。
    Browser-Solidity 也不停的更新中,截图可能和你看到的界面不一样。

    部署合约

    Browser-Solidity 生成的代码,拷贝到编辑器里修改后的代码如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    
    var _greeting = "Hello World" ;
    var helloContract = web3.eth.contract([{"constant":true,"inputs":[],"name":"say","outputs":[{"name":"","type":"string"}],"payable":false,"stateMutability":"view","type":"function"},{"inputs":[{"name":"_greeting","type":"string"}],"payable":false,"stateMutability":"nonpayable","type":"constructor"}]);
    var hello = helloContract.new(
       _greeting,
       {
         from: web3.eth.accounts[1],
         data: '0x6060604052341561000f57600080fd5b6040516102b83803806102b8833981016040528080518201919050508060009080519060200190610041929190610048565b50506100ed565b828054600181600116156101000203166002900490600052602060002090601f016020900481019282601f1061008957805160ff19168380011785556100b7565b828001600101855582156100b7579182015b828111156100b657825182559160200191906001019061009b565b5b5090506100c491906100c8565b5090565b6100ea91905b808211156100e65760008160009055506001016100ce565b5090565b90565b6101bc806100fc6000396000f300606060405260043610610041576000357c0100000000000000000000000000000000000000000000000000000000900463ffffffff168063954ab4b214610046575b600080fd5b341561005157600080fd5b6100596100d4565b6040518080602001828103825283818151815260200191508051906020019080838360005b8381101561009957808201518184015260208101905061007e565b50505050905090810190601f1680156100c65780820380516001836020036101000a031916815260200191505b509250505060405180910390f35b6100dc61017c565b60008054600181600116156101000203166002900480601f0160208091040260200160405190810160405280929190818152602001828054600181600116156101000203166002900480156101725780601f1061014757610100808354040283529160200191610172565b820191906000526020600020905b81548152906001019060200180831161015557829003601f168201915b5050505050905090565b6020604051908101604052806000815250905600a165627a7a723058204a5577bb3ad30e02f7a3bdd90eedcc682700d67fc8ed6604d38bb739c0655df90029',
         gas: '4700000'
       }, function (e, contract){
        console.log(e, contract);
        if (typeof contract.address !== 'undefined') {
             console.log('Contract mined! address: ' + contract.address + ' transactionHash: ' + contract.transactionHash);
        }
     });
    

    第 1 行:修改字符串为 Hello World
    第 2 行:修改合约变量名
    第 3 行:修改合约实例变量名,之后可以直接用实例调用函数。
    第 6 行:修改部署账户为新账户索引,即使用新账户来部署合约。
    第 8 行:准备付的 gas 费用,IDE 已经帮我们预估好了。
    第 9 行:设置部署回调函数。

    拷贝回 geth 控制台里,回车后,看到输出如:

    1
    
    Contract mined! address: 0x79544078dcd9d560ec3f6eff0af42a9fc84c7d19 transactionHash: 0xe2caab22102e93434888a0b8013a7ae7e804b132e4a8bfd2318356f6cf0480b3
    

     

    说明合约已经部署成功。

    在打开的 tail -f test.log 日志终端里,可以同时看到挖矿记录

    现在我们查看下新账户的余额:

    1
    
    > eth.getBalance(eth.accounts[1])
    

     

    是不是比之前转账的余额少呀!

    运行合约

    1
    2
    
    > hello.say()
    "Hello World"
    

    输出 Hello World,我们第一个合约 Hello World,成功运行了。

    运行截图如下:
    运行截图

    本文会随 geth,solidity 语言版本升级保持更新,查看本文原始链接:https://learnblockchain.cn/2017/11/24/init-env/

    展开全文
  • ASCH智能合约支持在MacOS、...由于ASCH智能合约开发环境基于Node.js及VSCode为搭建,除了基础依赖环境与系统平台相关外其余部分在不同平台上类似。故基础依赖环境分系统介绍,其余部分统一介绍。 1. 安装基础依...

    ASCH智能合约支持在MacOS、Ubuntu、和Windows三种平台下进行开发。基本安装步骤如下:

    • 安装基础依赖环境
    • 安装VSCode及相关插件
    • 安装ASCH智能合约开发工具
    • 安装本地节点(可选)

    由于ASCH智能合约开发环境基于Node.js及VSCode为搭建,除了基础依赖环境与系统平台相关外其余部分在不同平台上类似。故基础依赖环境分系统介绍,其余部分统一介绍。

    1. 安装基础依赖环境

    基础依赖环境主要包括:包管理工具(MacOS和Ubuntu)、Node版本管理工具(nvm)、Node.js 及 npm、node-gyp 以及C++编译所依赖的工具,下面分平台进行介绍。

    1.1. Windows环境

    支持Windows 8.1以上版本的Windows操作系统。以下操作在 Win10 x64 简体中文专业版 (版本 1809 17763.194)上验证通过

    • 安装 nvm-windows

    目前最新版为v1.1.7下载地址

    安装参考 注意使用管理员权限安装,否则安装node后可能无法在命令行中直接运行

     

    • 安装 node v10.14.1

    以管理员权限在命令行中运行下面的命令

    #安装
    nvm install 10.14.1
    
    #使用10.14.1版本
    nvm use 10.14.1
    
    #验证安装是否成功
    node -v
    
    #应该输出
    v10.14.1
    

    在Windows环境中如使用10.15.x版,可能会导致ASCH合约开发工具安装失败

    • 安装 node-gyp 及 C++编译工具

    以管理员权限运行下面的命令

    #安装 node-gyp
    npm i -g node-gyp
    
    #如果安装过程非常慢,请尝试
    npm i -g node-gyp --registry=https://registry.npm.taobao.org
    
    #安装 C++编译工具
    npm install --global --production windows-build-tools --vs2015

    注意,C++编译工具安装比较费时,视网络情况不同约需要2-4小时

    • 配置 node-gyp 编译参数
    #使用 vs2015版的Visual Studio项目文件格式
    npm config set msvs_version 2015

    1.2. MacOS环境

    以下操作在MacOS 10.14.4上验证通过

    • 安装 Homebrew

    Homebrew 是 macOS 平台的软件包管理器,相当于 Linux 常用的 apt-get。首先请确保已经安装XCode,如未安装,直接在AppStore中安装即可。

    # 安装
    /usr/bin/ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
    
    #验证
    brew -v
    
    #安装成功则显示版本信息,例如:
    Homebrew 1.9.1
    Homebrew/homebrew-core (git revision 46a29; last commit 2019-04-12)
    Homebrew/homebrew-cask (git revision 5ed4f; last commit 2019-04-12)
    
    • 安装 nvm 和 Node.js v10.15.1
    #安装nvm
    brew insall nvm
    
    #安装Node.js v10.15.1
    nvm install v10.15.1
    
    #切换默认版本
    nvm use 10.15.1
    
    #验证
    node -v
    
    #成功则输出
    v10.15.1
    
    • 安装 node-gyp 及 C++编译工具
    #安装相关编译工具
    brew install libtool autoconf automake
    
    #安装 node-gyp
    npm i -g node-gyp
    
    #如果安装过程非常慢,请尝试
    npm i -g node-gyp --registry=https://registry.npm.taobao.org

    1.3. Ubuntu环境

    支持Ubuntu14.04以上版本,以下安装在Ubuntu 16.04上验证通过

    • 安装系统工具库
    #安装系统依赖包
    sudo apt-get install curl ntp wget git libssl-dev openssl make gcc g++ autoconf automake python build-essential -y
    
    #Ubuntu 14.04请运行
    sudo apt-get install libtool -y
    
    # Ubuntu 16.04请运行
    sudo apt-get install libtool libtool-bin -y
    • 安装nvm 和 Node.js v10.15.1
    #安装 nvm
    curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.33.2/install.sh | bash
    
    #安装Node.js v10.15.1
    nvm install v10.15.1
    
    #验证
    node --v
    
    #应该输出
    v10.15.1
    
    • 安装 node-gyp
    #安装 node-gyp
    npm i -g node-gyp
    
    #如果安装过程非常慢,请尝试
    npm i -g node-gyp --registry=https://registry.npm.taobao.org

    2. 安装VSCode及相关插件

    请访问 VSCode官网,安装最新版VSCode。

    推荐安装 tslinttypescriptjest等常用插件

    3. 安装ASCH智能合约开发工具

    在Windows环境中请使用管理员权限的命令行工具

    #安装合约开发模板生成工具,
    npm i create-asch-contract -g
    
    #如果安装过程非常慢,请尝试
    npm i create-asch-contract -g --registry=https://registry.npm.taobao.org

    4. 安装本地节点(可选)

    请参考节点安装中的相关内容

    展开全文
  • 目前开发智能的IDE, 首推还是Remix, 而Remix官网, 总是由于各种各样的(网络)原因无法使用,本文就来介绍一下如何在本地搭建智能合约开发环境remix-ide并介绍Remix的使用。 写在前面 Remix 是以太坊智能合约编程...
  • 本教程主要解决两个问题:第一,细节丰富便于复现的极简智能合约开发流程,部署到公网以太坊测试网络并运行,熟悉这个流程,可以原封不动地切换到以太坊主网上进行开发;第二,安全原则,确保在以太坊上的各种操作...
  • 搭建智能合约开发环境

    千次阅读 2018-09-10 07:28:08
    编写智能合约 pragma solidity ^0.4.4; /** pragma : 版本声明 solidity : 开发语言 0.4.4 : 当前合约的版本, 0.4 代表朱版本, 后面代表修改的版本 ^ : 代表向上兼容,0.4.4 ~ 0.4.9 都可以对当前的代码...
  • 极短路径 http://www.jiduanlujing.com出品,《零基础一小时极简以太坊智能合约开发环境搭建并开发部署》即将发布。
  • 1、安装golang环境 参考中文官网:... ... 2、安装golang集成开发环境goland 参考:https://www.cnblogs.com/pergrand/p/13188081.html 3、从git上下载fabric-sample,快速获取合约示例代码 进入$GOPATH/sr
  • 以太坊合约开发最快速上手是使用remix-ide,用浏览器打开即可使用。不过喜欢折腾的话,就需要手动搭环境了,本文简单介绍了以太坊开发环境的搭建。 一、 搭建环境 本文使用的操作系统为Ubuntu 16.04。 以太坊...
  • 整体运行环境:在win10里面开启hyper-v虚拟机服务, 然后在虚拟机里面安装ubantu16.04系统, 接着在ubantu16.04系统里安装eosio, 包含命令行环境(cleos等)以及智能合约编译环境(eosio.cdt), 到这里就完成了...
  • 以太坊智能合约开发环境及总结

    千次阅读 2017-09-29 14:25:38
    这里在吸收了部分网络资源,及多次自我尝试后,较为详细总结了linux系统下利用truffle3.0+testrpc完成以太坊智能合约+DApp开发用到的环境搭建过程,并归纳了开发过程中遇到的一些问题及解决方案,合约编程...
  • 目前主要的智能合约开发语言是 Solidity语言,是一种开发以太坊智能合约的静态高级语言,语法类似于JavaScript。 Truffle 框架依赖Node,需要使用npm安装。首先需要安装node,npm会同时安装,下载node,按提示安装。...

空空如也

空空如也

1 2 3 4 5 ... 20
收藏数 11,245
精华内容 4,498
关键字:

智能合约开发环境