摘要:本文首发于深入浅出区块链社区原文链接实现一个可管理增发兑换冻结等高级功能的代币原文已更新,请读者前往原文阅读本文主要介绍代币高级功能的实现代币管理代币增发代币兑换资产冻结自动补充。
本文首发于深入浅出区块链社区
原文链接:实现一个可管理、增发、兑换、冻结等高级功能的代币原文已更新,请读者前往原文阅读
本文主要介绍代币高级功能的实现: 代币管理、代币增发、代币兑换、资产冻结、Gas自动补充。
写在前面在上一篇:一步步教你创建自己的数字货币(代币)进行ICO中我们实现一个最基本功能的代币,本文将在上一遍文章的基础上,讲解如果添加更多的高级功能。
实现代币的管理者虽然区块链是去中心化的,但是实现对代币(合约)的管理,也在许多应用中有需求,为了对代币进行管理,首先需要给合约添加一个管理者。
我们来看看如果实现,先创建一个owned合约。
contract owned { address public owner; function owned() { owner = msg.sender; } modifier onlyOwner { require(msg.sender == owner); _; } // 实现所有权转移 function transferOwnership(address newOwner) onlyOwner { owner = newOwner; } }
这个合约重要的是加入了一个函数修改器(Function Modifiers)onlyOwner,函数修改器是一个合约属性,可以被继承,还能被重写。它用于在函数执行前检查某种前置条件。
关于函数修改器可进一步阅读Solidity 教程系列10 - 完全理解函数修改器
如果熟悉Python的同学,会发现函数修改器的作用和Python的装饰器很相似。
然后让代币合约继承owned以拥有onlyOwner修改器,代码如下:
contract MyToken is owned { function MyToken( uint256 initialSupply, string tokenName, uint8 decimalUnits, string tokenSymbol, address centralMinter ) { if(centralMinter != 0 ) owner = centralMinter; } }代币增发
实现代币增发,代币增发就如同央行印钞票一样,想必很多人都需要这样的功能。
给合约添加以下的方法:
function mintToken(address target, uint256 mintedAmount) onlyOwner { balanceOf[target] += mintedAmount; totalSupply += mintedAmount; Transfer(0, owner, mintedAmount); Transfer(owner, target, mintedAmount); }
注意onlyOwner修改器添加在函数末尾,这表示只有ower才能调用这用函数。
他的功能很简单,就是给指定的账户增加代币,同时增加总供应量。
有时为了监管的需要,需要实现冻结某些账户,冻结后,其资产仍在账户,但是不允许交易,之道解除冻结。
给合约添加以下的变量和方法(可以添加到合约的任何地方,但是建议把mapping加到和其他mapping一起,event也是如此):
mapping (address => bool) public frozenAccount; event FrozenFunds(address target, bool frozen); function freezeAccount(address target, bool freeze) onlyOwner { frozenAccount[target] = freeze; FrozenFunds(target, freeze); }
单单以上的代码还无法冻结,需要把他加入到transfer函数中才能真正生效,因此修改transfer函数
function transfer(address _to, uint256 _value) { require(!frozenAccount[msg.sender]); ... }
这样在转账前,对发起交易的账号做一次检查,只有不是被冻结的账号才能转账。
代币买卖(兑换)可以自己的货币中实现代币与其他数字货币(ether 或其他tokens)的兑换机制。有了这个功能,我们的合约就可以在一买一卖中赚利润了。
先来设置下买卖价格
uint256 public sellPrice; uint256 public buyPrice; function setPrices(uint256 newSellPrice, uint256 newBuyPrice) onlyOwner { sellPrice = newSellPrice; buyPrice = newBuyPrice; }
setPrices()添加了onlyOwner修改器,注意买卖的价格单位是wei(最小的货币单位: 1 eth = 1000000000000000000 wei)
添加来添加买卖函数:
function buy() payable returns (uint amount){ amount = msg.value / buyPrice; // calculates the amount require(balanceOf[this] >= amount); // checks if it has enough to sell balanceOf[msg.sender] += amount; // adds the amount to buyer"s balance balanceOf[this] -= amount; // subtracts amount from seller"s balance Transfer(this, msg.sender, amount); // execute an event reflecting the change return amount; // ends function and returns } function sell(uint amount) returns (uint revenue){ require(balanceOf[msg.sender] >= amount); // checks if the sender has enough to sell balanceOf[this] += amount; // adds the amount to owner"s balance balanceOf[msg.sender] -= amount; // subtracts the amount from seller"s balance revenue = amount * sellPrice; msg.sender.transfer(revenue); // sends ether to the seller: it"s important to do this last to prevent recursion attacks Transfer(msg.sender, this, amount); // executes an event reflecting on the change return revenue; // ends function and returns }
加入了买卖功能后,要求我们在创建合约时发送足够的以太币,以便合约有能力回购市面上的代币,否则合约将破产,用户没法先合约卖代币。
实现Gas的自动补充以太坊中的交易时需要gas(支付给矿工的费用,费用以ether来支付)。而如果用户没有以太币,只有代币的情况(或者我们想向用户隐藏以太坊的细节),就需要自动补充gas的功能。这个功能将使我们代币更加好用。
自动补充的逻辑是这样了,在执行交易之前,我们判断用户的余额(用来支付矿工的费用),如果用户的余额非常少(低于某个阈值时)可能影响到交易进行,合约自动售出一部分代币来补充余额,以帮助用户顺利完成交易。
先来设定余额阈值:
uint minBalanceForAccounts; function setMinBalance(uint minimumBalanceInFinney) onlyOwner { minBalanceForAccounts = minimumBalanceInFinney * 1 finney; }
finney 是货币单位 1 finney = 0.001eth
然后交易中加入对用户的余额的判断。
function transfer(address _to, uint256 _value) { ... if(msg.sender.balance < minBalanceForAccounts) sell((minBalanceForAccounts - msg.sender.balance) / sellPrice); if(_to.balance代码部署 高级功能完整代码请前往我的小专栏, 项目的完整的部署方法参考上一篇,不同的是创建合约时需要预存余额,如图:
专栏已经有多篇文章介绍Remix Solidity IDE的使用,这里就不一一截图演示了,请大家自己测试验证。
如何创建代币发行代币,现在也录制了对应的视频教程:通过代币学以太坊智能合约开发
目前我们也在招募体验师,可以点击链接了解。如果你在创建代币的过程中遇到问题,欢迎到我的知识星球提问,作为星球成员福利,成员可加入区块链技术付费交流群。
参考文档Create your own crypto-currency with ethereum
深入浅出区块链 - 系统学习区块链,打造最好的区块链技术博客。
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/24111.html
摘要:本文首发于深入浅出区块链社区原文链接智能合约语言教程系列完全理解函数修改器原文已更新,请读者前往原文阅读这是教程系列文章第篇,带大家完全理解的函数修改器。在此上下文中,所有的函数中引入的符号,在修改器中均可见。 本文首发于深入浅出区块链社区原文链接:智能合约语言 Solidity 教程系列10 - 完全理解函数修改器原文已更新,请读者前往原文阅读 这是Solidity教程系列文章第10...
摘要:构造函数为空,参数为智能合约账户名。每个智能合约类都要继承类类构造函数创建代币函数声明函数,这个函数用来新建一种代币,并输入代币的各种属性,同时函数也是一个。 详解 EOS 智能合约的 hpp 文件 为了帮助大家熟悉 EOS 智能合约,EOS 官方提供了一个代币(资产)智能合约 Demo —— eosio.token。eosio.token 智能合约目前还不是特别完善,个别功能还没有完...
摘要:目前市场还未饱和,预期收益率较高。将矿池包装成依然无法掩盖矿池对去中心化社区进行破坏的本质。经济的典型代表,就在实践中意识到了去中心化的重要性。 showImg(https://segmentfault.com/img/bVbryaU?w=600&h=400);最近,一个叫做Staking经济的词突然在圈内火了起来,各大行业媒体扎堆报道。 什么是Staking? Staking翻译成中...
摘要:目前市场还未饱和,预期收益率较高。将矿池包装成依然无法掩盖矿池对去中心化社区进行破坏的本质。经济的典型代表,就在实践中意识到了去中心化的重要性。 showImg(https://segmentfault.com/img/bVbryaU?w=600&h=400);最近,一个叫做Staking经济的词突然在圈内火了起来,各大行业媒体扎堆报道。 什么是Staking? Staking翻译成中...
阅读 2503·2023-04-25 22:09
阅读 1021·2021-11-17 17:01
阅读 1543·2021-09-04 16:45
阅读 2617·2021-08-03 14:02
阅读 813·2019-08-29 17:11
阅读 3252·2019-08-29 12:23
阅读 1085·2019-08-29 11:10
阅读 3279·2019-08-26 13:48