深入浅出以太坊——ICO技术原理

什么是ICO

讲道理,抛开底下所谓区块链的技术噱头,ICO就是有一个人/组织,突然跑出来跟大家说:”我要做一个很牛逼的事,万事俱备,只差钱了!大家能否帮老夫众筹一把?“。然后所有出钱的人,他留一个记录:”xxx给了我多少多少钱,我以后一定涌泉相报!”

完了,就这么简单啊。

那为啥ICO这么火爆?

正常一个项目融资,需要各种审批手续,投资人需要各种资质,最后你还要去银行汇款或者买理财,总之各种不方便,特别是如果是国外的项目更不好参与,汇兑成本等等都是阻碍。

ICO基于区块链技术,让融资变得非常容易,用户只需要购买ETH(以太坊),然后发送给ICO的智能合约,合约会自动按照比例记录我们的份额。只需要轻轻一点,你就可以参与一个“原始股投资”,无论国籍,无论距离。但是,ICO只是让融资变得方便,并不是让它变得简单,投资需要智慧,见识,信息。而现在的ICO乱象,大部分人只是在赌后面会有人用更高的价格立刻接盘而已了。

老规矩,今天只谈技术,不谈多余的东西

ICO技术概要

ICO本质上是一堆智能合约,有关智能合约的概念请阅读之前的内容。最简单的ICO智能合约,就是用一个合约去记录一个mapping(address=>uint),每当有人汇过来ETH时,就自动在mapping里记录一下发送者地址和发送数量。

最简单版本的智能合约

一个super简单版本的ICO合约:

contract simpleICO {
   map(address=>uint);
   public investFrom; 
   address public owner; 
   function simpleICO(){
      owner = msg.sender; 
   } 
   function invest() payable {
     if(msg.value > 0) {
       investFrom[msg.sender] = msg.value; if(!owner.send(msg.value)) throw; 
     } else {
       throw; 
     } 
   }
}

这个合约一旦收到ETH投资,就会把资金转给合约的创建者,并且记录投资者地址和份额。

EC 20标准

以太坊的开发者们为了ICO技术的标准化,提出了一个token的概念和规范。每一个ICO,都会发行一种token,作为投资者份额的计数单元。为了方便各种智能合约操作token,有一个token的官方接口标准:EC20,里面规定了token的接口:

totalSupply

functiontotalSupply()constantreturns(uint256 totalSupply) 返回token总量

balanceOf

functionbalanceOf(address _owner)constantreturns(uint256 balance)返回指定地址owner目前的token数量

transfer

functiontransfer(address _to, uint256 _value)returns(bool success)将指定数量的token从msg.sender账户下转移给_to

transferFrom

function transferFrom(address _from, address _to, uint256 _value) returns (bool success)将指定数量token从_from账户转移到_to账户这个函数是给代理(某智能合约)使用的,_from账户必须授权该代理有操作其账户下token的权利,授权必须通过approve接口。

approve

functionapprove(address _spender, uint256 _value)returns(bool success)授权_spender地址可以操作msg.sender账户下最多数量为_value的token。

allowance

function allowance(address _owner, address _spender) constant returns (uint256 remaining)返回_owner给_spender授权token的剩余量

一个标准实现

实际的众筹项目需求肯定要复杂得多,有预分配token,定时开启众筹,众筹完成奖励,refund等多种业务需求,还有合约健壮性等安全要求,而且一般会用多个代理帐号去操作。这里有一个功能比较全的[开源实现](https://github.com/TokenMarketNet/ico)实现了大部分功能。它的主要组成包括:

StandardToken

token的一个标准实现。

MintableToken

可以随时增发的token。。。

Crowdsale

ICO功能基类,合约部署后有Prepareing, Prefunding, Funding, Success, Failure, Finalized, Refunding七种状态。

部署合约时,可以指定出价策略,众筹开始时间,结束时间,最低众筹目标。 支持定向/非定向众筹,提前预分配token份额等,可以随时查询众筹进度,收集到以太币数量。

Crowdsale开启众筹前,需要token owner去approve一定的数量给合约。

AllocatedCrowdsale

预先固定份额的ICO,token所有者可以通过approve划拨更多token给该合约。

还有很多细碎的小功能部分,就不一一展开了,总之,token类的主要功能就是记录当前的token分配,然后通过approve功能,授权各个crowdsale合约去售卖token。当用户去调用crowdsale的售卖接口时,crowdsale就会去call对应token的功能来实现分配。

只要实现了EC20标准接口的token,都是可以被crowdsale直接ICO的。就这么简单。。

欢迎关注我的微信公众号:

 

如无特殊说明,文章均为本站原创,转载请注明出处!

《深入浅出以太坊——ICO技术原理》有一个想法

发表回复

您的电子邮箱地址不会被公开。