什么是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的。就这么简单。。
棒棒哒