智能合约最初三分钟用5个CMT可以做什么?
很悲伤的消息是,在币圈大凉的环境下,按照现在的币价来算,只能买一瓶矿泉水。
但是这5个CMT在开发人员手里,大有用处!究竟发挥了什么作用,来CyberMiles开发者社区11月25日举办的2小时学会编写智能合约Workshop101看看。
HelloWorld
Helloworld是最简单的程序之一,也是大部分程序员编写的第一个程序。这次的workshop101也是从最基础的Helloworld智能合约开始。
这里要特别指出,HelloWorld部分的主讲人杨乐。她是CyberMiles的产品经理,与这次来参会的大多数人一样,在此之前,没有任何编程经验。只要你愿意,欢迎来到开发者社区小课堂的讲台。
说回正题,在正式部署执行Helloworld智能合约之前,我们需要在电脑上安装MetaMaskforCMT。这是一个安装在Chrome浏览器的钱包工具,它的主要功能是管理CyberMiles帐号私钥,实现从网页上直接支付CMTs(包括gas费)等功能。
安装过程比较简单,去官网https://www.cybermiles.io/metamask下载插件,之后在Chrome的扩展程序中打开开发者模式,将下载好的metamask4cmt.crx拖拽至Chrome的扩展程序页面。
QANplatform桥智能合约遭到攻击,建议不要执行QANX代币相关交易:10月11日消息,抗量子计算攻击的Layer1区块链QANplatform发推称,其桥智能合约遭到攻击,攻击者设法提取了代币,提醒用户不要执行任何与QANX代币相关的交易。目前团队正在调查问题。目前 QANX 价格短线跳水跌超 90%。[2022/10/11 10:30:53]
拖拽后,如果MetamaskforCMT不能正常工作,可以试下重启浏览器。如果依然不能正常工作,来参加workshop的程序员提供了一个新的方法,非常厉害,当天“拯救”了不少人的电脑。
把下载好的metamask4cmt.crx的后缀改成.rar,进行解压。在Chrome扩展程序页面,点击“加载已解压的扩展程序”,添加解压好的metamask4cmt.crx就可以了。
此外,如果Chrome中已经安装了其他版本的MetaMask,为了不影响使用,最好暂时停止使用其他版本的MetaMask,只留MetamaskforCMT激活。
安装好MetaMaskforCMT,就可以生成一个新的CyberMiles帐号来存储CMTs,在最上方选择MainCyberMilesNetwork。因为主办方会给每个人发5个真实的CMT,用于支付执行智能合约的gas费以及参与后面的神秘环节。
DFINITY社区批准了启用容器智能合约以转移ICP代币的提案:9月20日消息,DFINITY社区NSN提案(#20588)于9月17日获得通过,该提案建议使所有主体(包括容器)能够转移ICP实用程序代币,计划批准智能合约容器传输ICP,并扩大对所有主体类型的支持,取消特定限制以便所有主体可持有和转移ICP代币。同时,所有自认证和列入白名单的容器都可继续传输ICP。据悉,该提案的具体实施将需要几个月时间,研究团队将在未来向社区提出沙盒项目,其中将发生通常的“开放式设计”迭代过程。[2021/9/20 23:37:36]
CMT的转账速度非常快,差不多10秒就到账了,并且不用支付gas费,转账体验非常好!
有了5个CMT和MetaMaskforCMT,就可以开始我们的HelloWorld!
在Chrome里打开RemixforCMT的网页,将写好的HelloWorld智能合约代码放进中间的代码编辑区,当然,你也可以选择自己写代码。
之后点击右侧的Starttocompile,编译器会自动检查这段代码是否存在常规性错误。没有问题的话,编译器会自动识别出该段合约的名称,也就是Contract后面的Greet。如果有问题,编译器会给出提示,根据提示修改代码,再次编译即可。
代码检查没有问题后,就可以把Greet智能合约部署到CyberMiles区块链了。点击右侧最上方的Run,然后点击Deploy。
波场与WAVES达成战略合作 将利用Gravity连接区块链智能合约语言:据官方消息,波场已与WAVES达成战略合作,Waves和TRON将一起利用Gravity来连接各自区块链的智能合约语言,即Ride和Solidity。Gravity是一个无基础代币的预言机,具有跨链通信网络。TRON和Waves正在通过Gravity建立一座桥梁,这将允许两个生态系统为两个用户群提供更多的服务。波场和Waves的生态系统计划将这一趋势扩展到其他区块链生态系统并以此为链间DeFi行业带来革命性改变。波场 TRON 以推动互联网去中心化为己任,致力于为去中心化互联网搭建基础设施。旗下的 TRON 协议是基于区块链的去中心化应用操作系统协议之一,为协议上的去中心化应用运行提供高吞吐,高扩展,高可靠性的底层公链支持。波场 TRON 还通过创新的可插拔智能合约平台为以太坊智能合约提供更好的兼容性。[2020/8/14]
这时需要调用MetaMaskforCMT支付部署智能合约所需要的gas费。一般情况下,MetaMask的支付页面会自动跳出,点击Submit进行支付就可以了。如果没有自动跳出,手动点击插件就好了。
可以看到,部署这个合约上链只需要花费0.000489个CMT。
支付完gas费后,右下方DeployedContracts处就可以看到,我们的合约已经在CyberMiles链上部署好了。
声音 | 智能合约先驱:尽管都存在缺陷 但会选择ETC或RSK而非ETH:智能合约先驱尼克·萨博(Nick Szabo)近期在推特上回复推特网友提问时表示,ETC对PoW、DAO hack fork理念的坚守,都是人们支持ETC胜过ETH的好理由,它们反映了ETC支持者更加关注金融完整性。萨博称,ETH和ETC都是有缺陷的,但相较于ETH,我会选择ETC或RSK。我认为它们中没有哪个已经为严肃的金融应用做好准备,但是,在ETH上运行的那些项目除了可能是简单的代币之外,或许存在很高的风险。此外,他还将ETH称为“cult(邪教)”:一方面声称不变性和抗审查,另一方面攻击信任最小化原则,声称权力下放但却变得越来越集中化。[2019/10/17]
红色的terminate可以终止这个合约,但只有合约owner才可以执行这项操作,终止合约同样需要支持少量gas费。
greet显示智能合约的内容是什么,在这里是HelloWorld。当然,HelloWorld这个词只是程序员的选择。作为智能合约的开发者,你可以让greet()返回任何字符,可以是一首歌,一篇文章,一本书,或者是一段加密的文字。
owner显示这个合约的所有权归哪个地址所有。你为这个合约支付部署gas费的账号地址就是合约的所有者。
同时用区块浏览器www.cmttracking.io查询交易地址信息,可以看到刚刚创建的合约地址。如果你的朋友有这个合约地址,在AtAddress栏内输入合约地址,点击AtAddress就可以收到别致的智能合约问候啦!
Coinbase智能合约出现故障 允许用户无限取出ETH:据Cryptovest报道,Coinbase的智能合约被检测出现小故障,允许用户无限取出ETH。该漏洞存在大约1个月,截止漏洞发现时间,无人利用该漏洞获利。不过由于Coinbase账户均为实名验证,即使有人趁机浑水摸鱼,也能被系统检测、追踪。该漏洞在一项代码奖励计划中被发现,发现漏洞的荷兰公司获得1万美元奖励。[2018/3/22]
上面知道怎么用HelloWorld智能合约在区块链存一段话,并让世界上任何人看见这段话。那么,这是怎么在代码里实现的呢?
pragmality^1.2.4;
这是智能合约所用的代码语言及版本。
contractGreet{
functiongreet(){
}
functionterminate(){
}
}
以上代码介绍了智能合约的名字Greet,以及两个功能,greet和terminate。
addresspublicowner;
modifieronlyOwner(){
assert(msg.sender==owner);
_;
}
constructor()public{
owner=msg.sender;
}
以上代码设置了合约的owner,owner的地址信息是公开的。信息发送者,也就是谁支付了gas费,让合约能够部署到链上,谁就是owner,并且定义了只有owner能够修改这个合约。
functiongreet()publicpurereturns(string){
return"Helloworld";
}
以上代码表明当你调用greet()时,就会出现HelloWorld。这个功能只是从区块链上读取数据,所以不需要gas费用。这里你可以把HelloWorld改成任何文字。
functionterminate()externalonlyOwner{
selfdestruct(owner);
}
这就是智能合约最开始定义的terminate终止合约的功能,并且定义了只有Owner可以执行这项功能。selfdestruct是析构函数,用于销毁数据,终止合约。
到这里,HelloWorld的代码就结束了,这是一段非常完整的代码。
这个最基础的合约既设置了合约的Owner,同时也设置了Owner能够销毁合约,当执行selfdesruct时,合约里的钱也会返还给Owner。
因为合约地址与钱包地址长地非常像,并且长度也一致,如果不小心把币打到了合约地址,一般情况下,是无法找回的。但如果你知道合约的owner是谁,可以联系合约的owner,在销毁合约时拿回你的资产。
这只是个人的小损失,如果项目方没有认真地对待代码,带来的资产损失是非常严重的。非常典型的案例是,今年7月份,Polkadot有超过513,774.16ETH被冻结在Parity钱包中,就是因为合约中的owner被人设成null了,因此没有人可以终止合约,拿回存在合约里的钱。现在,钱仍然被锁在合约里,没有人可以拿回来。
谨慎对待,认真审查每一段代码,尤其是涉及到钱的代码,这是每个程序员该有的素质。
CyberMiles开发社区连最基础的HelloWorld智能合约代码也保证了完整性,值得学习。
Betgame竞猜小游戏
这次workshop还有进阶版,通过智能合约发起一个竞猜游戏,由智能合约当裁判,可以说具备了完全的公正性。
代码比较复杂,不再一一解释,有兴趣的朋友可以自行去github研究一下。https://github.com/CyberMiles/education/blob/master/meetups/beijing/2-smart-contract-101/bet_game.lity
Owner把智能合约部署在CyberMiles区块链上后,玩家可以在RemixforCMT中输入合约地址,调用该合约,参与竞猜游戏。
游戏规则是每个参加workshop的人先从2到12中随机选择一个整数,并为自己选择的数字支付一定数量的CMT作为注。如果猜对了,将获得等比例的CMT。
规则公布后,Owner选择startGame,游戏正式开始!大家在现场跃跃欲试,有人大声说着”allin”,有人应和着,现场一时异常欢乐。这也是5个CMT的神秘用处!
调用合约成功后,在右下方placeBet处填写自己选择的整数,在右上方Value处,将单位选择为CMT,并且填写自己准备花费多少钱。填好后,通过MetamaskforCMT支付gas费,将下来坐等开奖!
杨乐在微信中随机掷了两个骰子,确认了最终的正确答案。在骰子”尘埃落定”的过程中,一片安静,静悄悄地等最终答案,看来大家都沉浸在游戏中了。
正确答案出来后,合约Owner在endGame处填写数字8,并支付gas费。
接下来就是领奖环节,根据智能合约的规则,前面在placeBet填写了数字8的参与者就是赢家,将按比例平分收集到的所有下注的CMT。
赢家点击payme,支付gas费,合约将自动把分配好的CMT转账到赢家的CMT账户里,这一切由代码计算,执行。
现场有两位赢家,一位以0.5CMT拿走了5.3个CMT,一位以2CMT拿走21.2CMT。当然也有没猜中的同学不死心地点了payme,但是因为不是赢家,什么也没拿到,白白地支付了gas费。不相信智能合约是不行的。
结果公示,两位赢家拿走奖励后,Owner选择terminate这个合约,游戏到此圆满结束!
用5个CMT编写智能合约,和周围的小伙伴一起讨论这段代码该怎么理解,又有CMT开发社区的人热心指导,最后参与到有趣的游戏中,见证了什么叫做”Codeislaw”。
CyberMiles开发者社区组织的这次活动有着非常棒的体验,这也是区块链技术应有的魅力之处!
小广播:下期Workshop102将在12月9日举行,有兴趣的朋友可以进群了解更多。
点击阅读原文,查看本次workshop101的全部代码
近期,Bottos携基于其公链开发的DApp项目Datanno,与SWFTBlockchain达成战略合作关系.
1900/1/1 0:00:00NEO看涨期权代码周NEO看涨1127期权标的NEO合约类型欧式看涨期权计价单位USDT最小价格单位0.0001USDT合约比例2:1.
1900/1/1 0:00:00尊敬的用户:CoinTiger币虎交易平台的“50,000BTA空投TCH持有者”活动已经结束,活动奖励已发放至用户账户,请所有符合活动条件的用户在-中查询分发结果.
1900/1/1 0:00:00从11月29日以来,比特币的价格始终维持在4000美元以上,人们开始谈论近年来比特币和亚马逊等主流股票的走势.
1900/1/1 0:00:00尊敬的CoinMex用户:?为支持BitcoinCash的硬分叉,CoinMex将作出如下方案:?1、由于BitcoinCash硬分叉将可能出现BitcoinCashABC、BitcoinCas.
1900/1/1 0:00:00继YOYOW入驻慢雾区,发布「安全漏洞与威胁情报赏金计划」后,慢雾科技加入YOYOW见证人节点,进一步推动区块链公链技术.
1900/1/1 0:00:00