㈠ 什么是以太坊(Ethereum)imToken支持符合ERC20代币
以太坊(Ethereum)是一个开源的有智能合约功能的公共区块链平台。通过其专用加密货币以太币(Ether,又称“以太币”)提供去中心化的虚拟机(称为“以太虚拟机”Ethereum Virtual Machine)来处理点对点合约。以太坊的概念首次在2013至2014年间由程序员Vitalik Buterin受比特币启发后提出,大意为“下一代加密货币与去中心化应用平台”,在2014年通过ICO众筹得以开始发展。
以太坊不仅是一个数据库,它还允许你在区块链的可信环境中运行程序。以太坊在区块链上搭建了一个名为 EVM(Ethereum Virtual Machine,以太坊虚拟机)的虚拟机。EVM 允许在区块链上验证和执行代码,为代码在每个人的机器上以相同方式运行提供保障。这些代码包含在智能合约中。除了追踪账户余额,以太坊使用相同方法将 EVM 的状态保存在区块链上。所有节点处理智能合约,来验证合约本身及其输出的完整性。
㈡ 002:以太坊简介|《ETH原理与智能合约开发》笔记
待字闺中开发了一门区块链方面的课程:《深入浅出ETH原理与智能合约开发》,马良老师讲授。此文集记录我的学习笔记。
课程共8节课。其中,前四课讲ETH原理,后四课讲智能合约。
第一课分为四部分:
这篇文章是第一部分的学习笔记:以太坊简介。
以太坊是目前公认的区块链2.0,相比于区块链1.0(比特币),其最大的特点是引入了智能合约,从而从单一的数字加密 Token 技术转化为一个区块链分布式应用的平台。以太坊本身不包含任何具体的应用,它主要是提供基础平台和工具,使得开发者可以在其基础之上开发出各种各样的应用。可以说,以太坊有着巨大的潜力,它最终可能会发展出分布式、自动化、自组织的最高形态。
第一,我们可以通过学习以太坊的技术,领会区块链技术发展的脉络,改进的思路/路径,从而紧跟区块链技术发展的前沿,预测下一步的趋势。
第二,DAPP(分布式应用)生态系统目前的发展也是蒸蒸日上,蓬勃发展,据不完全统计,现在有数百种应用之多,显而易见的,对于开发人员的需求也是水涨船高,需要大量的开发人员。目前非常有名的应用有加密猫、各类侧链应用、ERC20 Token如币安币火币等等。
2013年,创始人 Vitalik Buterin 针对比特币存在的一些问题以及局限性,提出把“智能合约”构想应用于区块链领域,希望打造一个基于区块链的多方计算的智能化通用平台,并通过比特币融资进行开发。
2014年,以太坊基金会在瑞士成立,管理并运营整个项目。
前5大矿池占83%的算力,很集中。
目前大约有16000个全节点,其中,美国5461(34%),中国1839(11.5%),俄罗斯963(6%),德国920(5.7%),加拿大875(5.45%)。全节点每天都有动态变化。分布情况也反映出各个国家的参与热度。
㈢ 智能合约是什么
智能合约是一款计算机软件,其被设计为自动化自我实施合同,这意味着它触发某些动作预定条件满足后自动执行。例如,智能合约可以用作数字协议,在双方之间进行加密货币(或任何其他数字资产)的交换。一旦设定了协议条款,智能合约就会验证它们的履行情况,并据此分配资产。
换句话说,智能合约基本上是在满足特定条件时执行特定功能的代码行。代码通常遵循触发预定和可预测操作的“if... then...”语句。
例如,一家在线商店可能会实施一个智能合约,以确保“如果收到付款,则交付产品”——这将使整个过程更高效,更不容易出现人为错误。
尽管智能合约在区块链和加密货币的背景下变得流行,但这个概念最早由美国密码学家 Nick Szabo 于 1994 年描述,比比特币早很多年。
智能合约在区块链空间和加密货币市场中发挥着重要作用,尤其是在 ERC-20 代币方面,它代表了在以太坊网络上创建的一类遵循ERC-20标准的代币。这些代币通常通过首次代币发行活动分发,而智能合约的使用可以在销售期间实现无需信任且具有成本效益的资金交换。它们的使用还可以促进去中心化应用程序 ( DApp ) 或去中心化交易所 ( DEX ) 的支付处理。
智能合约适用的另一个领域是金融服务行业。例如,该技术可用于自动化交易的清算和结算、债券息票的支付,甚至保险索赔的计算和支付。
尽管它们在金融领域有着明显的应用,但智能合约的用途广泛,几乎适用于任何需要在各方之间转移资金、数字资产或任何类型的数字信息的行业。例如,设备租赁行业在现实世界中广泛使用这些合同,以提高租赁协议的效率。
在医疗保健领域,正在 探索 该技术作为对抗临床试验中数据操纵的对策。智能合约甚至可以通过建立共享所有权的明确记录并相应地分配知识产权的所有版税和收益来执行知识产权协议。
㈣ 使用Nodejs部署智能合约
实现智能合约的方式很多种,可以用truffle框架来实现,编译,部署。
这里介绍一种简单的使用nodejs来实现,编译,部署的方法。
创建一个nodejs项目,实现一个简单的智能合约。
这个合约实现了一个造币和转币的逻辑。
我们的合约是运行在evm上面的字节码,solidity是静态语言,需要通过编译器生成evm的字节码。
调用 node compile.js ,对BaseToken进行编译,生成字节码。web3中提供了一个部署合约的接口,使用如下,
利用编译生成的abi和bytecode,创建一个合约对象,然后进行发布,等待着异步执行的方法输出合约地址 contractAddress ,这样就完成了部署。不过这种方式有一个问题,就是在发布合约时,你的私钥处于联网状态,
处于安全策略,我们需要尽量避免私钥在联网状态。
以太坊上部署合约是向空地址发送一个附有字节码的签名交易,其中发送者就是这个合约的拥有者。因此我们只需要将合约构建成一笔交易,我们在无网状态下对这笔交易进行签名,然后将签名发送到以太坊网络中。这样能够降低我们私钥被泄漏的风险。
对合约的签名方法如下:
以上对一个合约签名,这里需要注意的问题是,to的地址需要是,空地址。
完成签名之后,我们把这笔交易发送出去就好,最简单的方法就是使用 etherscan的发送Tx的方式 ,一旦发送完成,部署完成,就可以看到合约地址。