以太坊私有链上发行代币

文章目录

  • 1. 发行代币
    • 1.1 准备山寨的代币发行账号
    • 1.2 定义山寨的代币智能合约
    • 1.3 创建山寨币智能合约
    • 1.4 初期发行1万贯山寨币
    • 1.5 再次增发5千贯山寨币
  • 2. 发年终奖
  • 3. 还钱转账
  • 4. 购物消费
  • 5. 代币兑换

上一篇文章我们介绍了如何在同一台机器上搭建包括两个节点的以太坊私有链网络。本文我们继续使用该网络,介绍如何在以太坊私有链上发行电子代币,本文使用的以太坊私有链钱包是Ethereum Wallet

假设有一个山寨需要分两次一共发行1万5千贯山寨币,该山寨币可以在山寨内部各处流通,山寨币的持有者可以随时到山寨的好汉钱庄兑换等值铜钱。基于此背景,我们考虑如何使用以太坊私有链完成如下山寨需求 :

  1. 发行代币
    1. 初始发行数量1万贯;
    2. 随后增发数量5千贯;
  2. 发年终奖
    1. 李逵 : 4000 贯
  3. 还钱转账
    1. 李逵归还借武松的200贯买牛肉钱;
  4. 购物消费
    1. 李逵从孙二娘处花20贯打了一壶酒;
  5. 代币兑换
    1. 孙二娘到好汉钱庄将20贯换成等值铜钱;

1. 发行代币

1.1 准备山寨的代币发行账号

山寨要想在以太坊私有链上发行自己的代币,必须首先要有属于山寨自己的钱包地址,比如说是 :

名称 : ShanZhai 
地址 : 0x0C5Ae7c2520b1208d579bCF8b2bF624EdD7a025c  
  • 山寨以太坊私有链账户截图 :
    以太坊私有链上发行代币_第1张图片

要想在以太坊私有链上开展各项业务,账户里必须有先有以太币,山寨的账户也不例外,以下李逵,武松,孙二娘的账户也不例外。

1.2 定义山寨的代币智能合约

现在山寨已经准备好了自己的区块链账号,接下来要想发行代币,必须先定义自己的山寨币智能合约:

pragma solidity ^0.4.18;

contract ShanZhaiCoin {
    // 发币人地址
    address public minter;
	
    // 代币名称
    string public coinName="山寨币";
	
    // 代币的单位
    string public coinUnit="贯";
	
	
    // 潜在地为每个被操作的地址创建一个变量 balances,
    // 类型为 unit, 用于表示该地址中该代币的余额,初始值为 0,
    // 通过该变量 balances, 合约通过该变量获取或者设置某个地址
    // 上该代币的余额,	
    mapping (address => uint) public balances;


    // 该智能合约的构造函数,仅在该智能合约创建时被调用,
    // 调用时将发币人地址设置成消息的发送者,也就是说,
    // 创建该智能合约实例的人会被设置为发币人
    constructor() public {
        minter = msg.sender;
    }

    // 发币人发行一定数量的代币
    // 可用于初始发行或者后期增发
    // 要求调用者地址和最初创建该智能合约的地址必须一致,
    // 也就是说,只有该智能合约实例的创建者才能发行/增发该代币
    function mint(uint amount) public {
        // 要求调用者地址 msg.sender 和 该智能合约实例创建人 minter
        // 必须相同, 也就是只有该智能合约实例的创建人才能发行/增发
        // 该代币		
        require(msg.sender == minter);
		
        // 单次发行量不能大于 10的60次方
        require(amount < 1e60);
		
        // 往发币人地址上增加指定数量的该代币
        balances[minter] += amount;
    }


    // 从调用者地址往指定地址 receiver 发送指定数量的代币,
    // 也就是一般意义上的转账功能
    // 从任何地址都可以发起,只要该地址拥有足够的该代币
    function send(address receiver, uint amount) public {
        require(amount <= balances[msg.sender], "Insufficient balance.");
        // 转账发起方账户扣减指定数量代币
        balances[msg.sender] -= amount;
        // 转账接收方账户增加指定数量代币
        balances[receiver] += amount;		
    }
}

在这个合约中,我们进行了如下信息:

  1. 属性 minter 表示发币人地址, 该属性必须在智能合约创建时设定;
  2. 属性 coinName 表示代币名称,并且不提供修改;
  3. 属性 coinUnit 表示代币单位,并且不提供修改;
  4. 潜在对应到每个地址的属性 balances , 表示该地址的账户余额,可以读取和修改;
  5. 方法 constructor , 智能合约的构造函数,仅在智能合约创建时被执行,接受一个参数表示发币人地址;
  6. 方法 mint, 表示发行指定数量的代币,仅仅允许发币人调用,并且每次发行数量不得大于10的60次方;
  7. 方法 send,表示调用者向其他地址账户转账;

1.3 创建山寨币智能合约

Ethereum Wallet中,点击界面右上角的CONTRACTS进入到合约界面,按照下图提示创建山寨币的智能合约 :

以太坊私有链上发行代币_第2张图片

点击部署之后,钱包会提醒输入账户ShanZhai的密码,输入其密码,点击SEND TRANSACTION继续即可,如下图所示 :
以太坊私有链上发行代币_第3张图片

确保私有链上有矿工正在挖矿,那么在WAllETS界面下方,你会看到该智能合约实例账户正在被创建,当进度达到12/12时,山寨币智能合约账户就创建好了。

在这里插入图片描述

好了,现在山寨币智能合约账户已经创建了,如下所示 :

名称 : Shan Zhai Coin (根据相应智能合约的名称自动生成)
地址 : 0x0182bB09435a77307D9B1540bDe6f42f9D3d16D3

以太坊私有链上发行代币_第4张图片

在上图界面中点击该账户图表即可进入该账户钱包的主界面,如下图所示 :

以太坊私有链上发行代币_第5张图片

从此图不难看出,我们在智能合约中定义和创建过程中指定的一些属性,已经在这里显示了出来 :

Minter : ShanZhai (这是我们代币发行者的地址的名称)
Coin name : 山寨币 (这是所发行的代币的名称,在智能合约中已经设定)
Coin unit : 贯 (这是所发行的代币的单位,在智能合约中已经设定)

接下来我们看看发币账号中该代币的余额 :
以太坊私有链上发行代币_第6张图片

Balances 属性下面的Address输入栏中输入发币人ShanZhai的地址,下面出现数字0,这表明发币人账户中山寨币的余额为0。这是符合我们预期的一个结果,因为我们尚未发行代币。

1.4 初期发行1万贯山寨币

在合约账户的右下方,我们选择功能Mint,设置发行数量Amount10000,指定发行者账号为ShanZhai,点击EXECUTE发起发行1万山寨币,如下图所示 :

以太坊私有链上发行代币_第7张图片

执行该代币发行事务同样需要消耗发行者账户的以太币,以及需要提供发行者的账户密码,有了这些信息,该发行代币动作和创建该执行合约没什么不同,都是作为一个事务交给底层区块链矿工挖矿完成。

以太坊私有链上发行代币_第8张图片

1.5 再次增发5千贯山寨币

增发代币和初期发行代币有什么不同吗 ?如果从实际业务需求的角度上没有这方面的约束和限制,就可以认为是没有。上面智能合约所定义的山寨币,就可以忽略其不同,所谓增发,就是再执行一次发行山寨币。所以重复上面1.4小节的动作,指定发行数量为5000,即可完成增发任务。增发之后,通过"Balances"方法查询发行人"ShanZhai"的山寨币余额,现在应该是15000贯。如下图所示 :
以太坊私有链上发行代币_第9张图片

从上面我们定义山寨币智能合约的代码来看,我们约定了只能由智能合约的创建人来发行代币。那么,上面的智能合约是由"ShanZhai"创建的,其他账号可以用来发行山寨币吗 ?

接下来,我们用李逵的账号试一试,假设李逵的账号是 :

名称 : LiKui
地址 : 0xbd5dd112d243f1D7899708667AE47A1b9AeBe902

这次发行代币过程中我们选择了使用李逵的账号发行山寨币,这是一个不同于山寨币所属智能合约创建者山寨ShanZhai的一个账号,结果,虽然可以输入密码后将事务发送到区块链处理,但是处理完成之后,李逵的账号中并没有山寨币 :
以太坊私有链上发行代币_第10张图片

这正是我们上面智能合约中代币发行逻辑所限制的,只能由智能合约创建者发行代币 :

        // 要求调用者地址 msg.sender 和 该智能合约实例创建人 minter
        // 必须相同, 也就是只有该智能合约实例的创建人才能发行/增发
        // 该代币		
        require(msg.sender == minter);

2. 发年终奖

山寨币已经发行了,现在山寨要给李逵发年终奖了。山寨之外的世界发奖金比较复杂,扣除各种税,进行各种登记,然后转账。山寨里就比较简单了,在"Shan Zhai Coin"山寨币主界面上,直接转账 :

以太坊私有链上发行代币_第11张图片

确保矿工在挖矿,转账事务处理完成后,我们分别看看山寨的账户和李逵的账户 :

  • 山寨的账户余额
    以太坊私有链上发行代币_第12张图片

因为给李逵发奖金,4000贯已经被所发行的15000贯中扣除了,所以剩下了11000贯。

  • 李逵的账户余额
    以太坊私有链上发行代币_第13张图片

看来李逵的奖金到账了。

3. 还钱转账

有了钱,李逵要做的第一件事情是还钱,毕竟山寨里都是好汉,好汉的信誉都很重要。现在,李逵要还掉从武松那里借来买牛肉的200贯钱。现在李逵这里有武松的山寨币账号 :

名称 : WuSong
地址 : 0x7dB957E34f634B97E47A632D65C3c520F4E820df

现在其余额是 :
以太坊私有链上发行代币_第14张图片

借钱的时候,武松并没有让李逵打什么借条之类的凭据,所以还钱这件事情很简单,李逵只需要转账200贯钱给武松即可。在"Shan Zhai Coin"山寨币主界面上,我们执行这个转账操作:
以太坊私有链上发行代币_第15张图片

提交以上转账事务,提供李逵账户的密码,确保矿工在挖矿,转账就能成功。我们来看看该转账完成时的情况。

  • 李逵的账户余额
    以太坊私有链上发行代币_第16张图片

  • 武松的账户余额
    以太坊私有链上发行代币_第17张图片

可以看到,李逵给武松的还钱转账已经完成了。

4. 购物消费

还完了帐,李逵手里还有钱,现在他要去孙二娘那里打壶酒喝。孙二娘给李逵打了一壶酒,李逵要支付孙二娘20贯酒钱。孙二娘让李逵把山寨币转到自己的这个账号 :

名称 : SunErNiang
地址 : 0xEB851F746ea8693E5776dAe1cdeF80C2c32b8dbC
  • 李逵的账户余额
    以太坊私有链上发行代币_第18张图片

  • 孙二娘的账户余额
    以太坊私有链上发行代币_第19张图片

可以看出,李逵买酒的钱已经转账山寨币给孙二娘了。

5. 代币兑换

过了一段时间,店里的酒卖的差不多了,孙二娘需要到山下进货。山寨币虽然在山寨流通,山下却用不了。孙二娘需要到山寨的好汉钱庄将山寨币兑换成山下能用的铜钱。

要想兑换出铜钱,孙二娘需要先把自己的山寨币转账给好汉钱庄。钱庄让孙二娘把要兑换的山寨币转到这个地址 :

名称 : ShanZhai 
地址 : 0x0C5Ae7c2520b1208d579bCF8b2bF624EdD7a025c

孙二娘一看,这不就是山寨最初发行山寨币的那个地址么。没错,好汉钱庄是山寨开的,兑换山寨币的话就需要先将山寨币通过好汉钱庄转回给山寨的山寨币账号。

  • 兑换前山寨账户里还有这么多山寨币
    以太坊私有链上发行代币_第20张图片
  • 兑换前孙二娘账户里余额有1000贯
    以太坊私有链上发行代币_第21张图片

开始帮孙二娘转账,这段时间一共收了1000贯山寨币,她都需要兑换 :
以太坊私有链上发行代币_第22张图片

同样地,需要提供孙二娘账户的密码和矿工挖矿该转账事务才能被处理。处理成功后,看一下转账结果:

  • 兑换后山寨账户里多出1000贯
    以太坊私有链上发行代币_第23张图片

  • 兑换后孙二娘账户里余额有0贯
    以太坊私有链上发行代币_第24张图片

转账成功,没有问题,好汉钱庄给了孙二娘1000贯铜钱。孙二娘离开了钱庄。

你可能感兴趣的:(区块链)