ICO技术探秘

ok,今天要讲的就是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

    function totalSupply() constant returns (uint256 totalSupply)
    返回token总量

  • balanceOf

    function balanceOf(address _owner) constant returns (uint256 balance)
    返回指定地址owner目前的token数量

  • transfer

    function transfer(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

    function approve(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的。就这么简单。。

QQ群:654894791

微信公众号: 94ETH

官网: https://www.94eth.com

头条号: 周期与泡沫


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。