智能合約最初三分鐘用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的擴展程序頁面。
Looks Rare開源Exchange V1智能合約:5月16日消息,NFT市場Looks Rare宣布開源其Exchange V1智能合約,包括核心交易合約、Librarie、目前的管理者合約、執行管理者和策略合約以及版稅相關合約。Looks Rare表示,未來Looks Rare將完全開源。[2022/5/17 3:20:37]
拖拽后,如果MetamaskforCMT不能正常工作,可以試下重啟瀏覽器。如果依然不能正常工作,來參加workshop的程序員提供了一個新的方法,非常厲害,當天“拯救”了不少人的電腦。
把下載好的metamask4cmt.crx的后綴改成.rar,進行解壓。在Chrome擴展程序頁面,點擊“加載已解壓的擴展程序”,添加解壓好的metamask4cmt.crx就可以了。
此外,如果Chrome中已經安裝了其他版本的MetaMask,為了不影響使用,最好暫時停止使用其他版本的MetaMask,只留MetamaskforCMT激活。
安裝好MetaMaskforCMT,就可以生成一個新的CyberMiles帳號來存儲CMTs,在最上方選擇MainCyberMilesNetwork。因為主辦方會給每個人發5個真實的CMT,用于支付執行智能合約的gas費以及參與后面的神秘環節。
CMT的轉賬速度非常快,差不多10秒就到賬了,并且不用支付gas費,轉賬體驗非常好!
DFINITY開發與BTC區塊鏈交互的智能合約:2月24日,官方消息,DFINITY開發了一種直接與比特幣區塊鏈交互的系統,允許開發人員構建canister智能合約,該智能合約可以運行直接與BTC區塊鏈交互的代碼。[2022/2/24 10:12:05]
有了5個CMT和MetaMaskforCMT,就可以開始我們的HelloWorld!
在Chrome里打開RemixforCMT的網頁,將寫好的HelloWorld智能合約代碼放進中間的代碼編輯區,當然,你也可以選擇自己寫代碼。
之后點擊右側的Starttocompile,編譯器會自動檢查這段代碼是否存在常規性錯誤。沒有問題的話,編譯器會自動識別出該段合約的名稱,也就是Contract后面的Greet。如果有問題,編譯器會給出提示,根據提示修改代碼,再次編譯即可。
代碼檢查沒有問題后,就可以把Greet智能合約部署到CyberMiles區塊鏈了。點擊右側最上方的Run,然后點擊Deploy。
這時需要調用MetaMaskforCMT支付部署智能合約所需要的gas費。一般情況下,MetaMask的支付頁面會自動跳出,點擊Submit進行支付就可以了。如果沒有自動跳出,手動點擊插件就好了。
可以看到,部署這個合約上鏈只需要花費0.000489個CMT。
The Sandbox ASSET 智能合約出現重復漏洞,已部署新合約:官方消息,去中心化虛擬游戲平臺沙盒游戲 The Sandbox 表示,The Sandbox ASSET 智能合約很容易出現重復問題,目前還沒有惡意用戶利用該漏洞進行攻擊,其他所有智能合約均不受影響,SAND 和 LAND 智能合約也沒有風險。另外,The Sandbox 已于 1 月 13 日告知交易 The Sandbox ASSET 的所有主要交易平臺(包括 OpenSea、Arkane Marketplace、Lootex、Playdapp 和 iNFT),這些交易平臺已于 2021 年 1 月 16 日 UTC 00:01 暫停了 ASSET 的交易。The Sandbox 表示,「該漏洞由 Optimism 安全研究員 Maurelian 于 1 月 4 日提出,允許用戶在使用 batchTransfer 函數時將向自己發送代幣。之后我們進行了內部上測試確認了該問題,1 月 5 日至 14 日之間進行了修復,并提交給 Solidified 安全審計員再次審計,1 月 15 日部署了新的智能合約,并于 1 月 16 日 12:00PM UTC 進行了快照,目前已開始將 ASSET 副本重新分配給持有者,將在 UTC1 月 18 日 00:00 之前完成所有用戶的 ASSET 恢復。」The Sandbox 表示,The Sandbox 此前通過了 Certik 和 Solidified 的審計,ASSET 智能合約最初于 2019 年 9 月 4 日由 Solidified 審計,當時三名審計員進行了為期 2 周的審計。The Sandbox 平臺的關鍵功能之一是可以從零開始創造素材資產 (ASSET),將其上傳到市場,然后通過區塊鏈貨幣化。[2021/1/16 16:20:46]
支付完gas費后,右下方DeployedContracts處就可以看到,我們的合約已經在CyberMiles鏈上部署好了。
歷史上的今天丨騰訊《區塊鏈智能合約安全技術要求》標準獲CCSA TC8立項:2019年11月24日,由中國通信標準化協會主辦、深圳市騰訊計算機系統有限公司承辦的網絡與信息安全技術工作委員會(CCSA TC8)第二十六次全會在廣州市順利落幕。騰訊公司在云服務和區塊鏈兩大領域提出的《云客戶信息安全管理體系評估指南》和《區塊鏈智能合約安全技術要求》兩項標準在會上成功立項,助力互聯網信息安全標準化體系的建立健全,為產業互聯網的安全發展提供新的保障。[2020/11/24 21:58:41]
紅色的terminate可以終止這個合約,但只有合約owner才可以執行這項操作,終止合約同樣需要支持少量gas費。
greet顯示智能合約的內容是什么,在這里是HelloWorld。當然,HelloWorld這個詞只是程序員的選擇。作為智能合約的開發者,你可以讓greet()返回任何字符,可以是一首歌,一篇文章,一本書,或者是一段加密的文字。
owner顯示這個合約的所有權歸哪個地址所有。你為這個合約支付部署gas費的賬號地址就是合約的所有者。
同時用區塊瀏覽器www.cmttracking.io查詢交易地址信息,可以看到剛剛創建的合約地址。如果你的朋友有這個合約地址,在AtAddress欄內輸入合約地址,點擊AtAddress就可以收到別致的智能合約問候啦!
現場丨Chainlink聯合創始人:預言機是將智能合約連接至鏈下世界的關鍵:金色財經現場報道,由Web3基金會主辦的Web3大會10月29日在上海舉行。Chainlink聯合創始人Sergey Nazarov在會上表示,目前智能合約已經邁入鏈下連通階段,有金融、國際貿易、保險等越來越多的場景被覆蓋,但它們都需要數據輸入如價格數據,這些數據都需要以某種形式傳輸到區塊鏈上。現在的趨勢就是將腳本化智能合約連接至鏈下世界,而預言機則是實現這一趨勢的關鍵。這一趨勢將驅動DeFi智能合約實現極大增長。[2020/10/29]
上面知道怎么用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的全部代碼
Tags:CMTNERWOROWNBTCMT價格DeFinerMOVE NetworkTop Down Survival Shooter
DragonEx項目2018年進度簡報 2018-12-07 親愛的用戶: 一.重大事件: 12月3日上線擲骰子游戲。首發24小時內參與人次47307,參與人次峰值11613/小時.
1900/1/1 0:00:00DragonToken:DailyDividends2018/12/01 2018-12-02 1DTDividend 黑客通過Monkey Drainer網絡釣魚獲利1297.
1900/1/1 0:00:00親愛的用戶:?? IDAX將上線PIVX。開通PIVX/BTC、PIVX/USDT交易,立即前往.
1900/1/1 0:00:00尊敬的LBank用戶: ??LBank將于12月初全球首發上線IDA/LBCN與IDA/USDT交易對,提現功能也將同步開通.
1900/1/1 0:00:00親愛的Bit-Z用戶: BZ生態代幣第一季回購銷毀計劃即日起正式啟動。Bit-Z集團將于香港時間11月19日向市場投放150萬USDT回購BZ代幣,此計劃預計15天內全部完成.
1900/1/1 0:00:00活動時間:11月30日00:00:00-12月10日23:59:59活動獎勵:1,000,000M2O 活動規則: 1活動期間,IDAX實名用戶加入M2O官方電報群,即可獲得100M2O.
1900/1/1 0:00:00