以太坊和智能合約_第1頁(yè)
以太坊和智能合約_第2頁(yè)
以太坊和智能合約_第3頁(yè)
以太坊和智能合約_第4頁(yè)
以太坊和智能合約_第5頁(yè)
已閱讀5頁(yè),還剩37頁(yè)未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

以太坊和智能合約數(shù)據(jù)服務(wù)事業(yè)部2017-04-102021/6/271PPT模板:/moban/PPT素材:/sucai/PPT背景:/beijing/PPT圖表:/tubiao/PPT下載:/xiazai/PPT教程:/powerpoint/資料下載:/ziliao/范文下載:/fanwen/試卷下載:/shiti/教案下載:/jiaoan/PPT論壇:PPT課件:/kejian/語(yǔ)文課件:/kejian/yuwen/數(shù)學(xué)課件:/kejian/shuxue/英語(yǔ)課件:/kejian/yingyu/美術(shù)課件:/kejian/meishu/科學(xué)課件:/kejian/kexue/物理課件:/kejian/wuli/化學(xué)課件:/kejian/huaxue/生物課件:/kejian/shengwu/地理課件:/kejian/dili/歷史課件:/kejian/lishi/Part1Part2Part3Part4主要內(nèi)容以太坊Demo演示智能合約Solidity2021/6/272Part1以太坊2021/6/273比特幣的腳本的缺點(diǎn)不支持循環(huán)語(yǔ)句缺少圖靈完備UTXO不可分割價(jià)值盲UTXO智能是已花費(fèi)或未花費(fèi)缺少狀態(tài)比特幣的腳本局限性內(nèi)置有圖靈完備編程語(yǔ)言以太坊2021/6/274以太坊介紹以太坊通過(guò)建立終極的抽象的基礎(chǔ)層-內(nèi)置有圖靈完備編程語(yǔ)言的區(qū)塊鏈-使得任何人都能夠創(chuàng)建合約和去中心化應(yīng)用,并在其中設(shè)立他們自由定義的所有權(quán)規(guī)則、交易方式和狀態(tài)轉(zhuǎn)換函數(shù)。以太坊虛擬機(jī)(EVM)是以太坊中智能合約的運(yùn)行環(huán)境。它不僅被沙箱封裝起來(lái),事實(shí)上它被完全隔離,也就是說(shuō)運(yùn)行在EVM內(nèi)部的代碼不能接觸到網(wǎng)絡(luò)、文件系統(tǒng)或者其它進(jìn)程。甚至智能合約與其它智能合約只有有限的接觸。2021/6/275以太坊賬戶用戶用公鑰、私鑰控制由合約編譯后的code控制合約賬戶外部賬戶相同的地址空間相同的數(shù)據(jù)結(jié)構(gòu)不同的功能包含四個(gè)部分:隨機(jī)數(shù),用于確定每筆交易只能被處理一次的計(jì)數(shù)器,參與生成交易的id賬戶目前的以太幣余額,以太幣(Ether)是以太坊內(nèi)部的主要加密燃料,用于支付交易費(fèi)用。以太幣的最小單位為Wei,最大單位為以太,1Ether=10^18Wei賬戶的合約代碼,如果有的話賬戶的存儲(chǔ)(默認(rèn)為空)2021/6/276交易交易包含以下內(nèi)容:消息的接收者地址用于確認(rèn)發(fā)送者的簽名要發(fā)送的以太幣的數(shù)量可選的數(shù)據(jù)(合約的參數(shù))STARTGAS:用來(lái)限制合約最多執(zhí)行多少次運(yùn)算GASPRICE:每次計(jì)算需要支付的費(fèi)用每5個(gè)Byte需要1個(gè)Gas防止死循環(huán)交易費(fèi)用=STARTGAS*GASPRICE對(duì)計(jì)算資源、存儲(chǔ)資源、帶寬的消耗都用Gas支付外部賬戶發(fā)送交易2021/6/277消息消息包含五個(gè)部分:消息的發(fā)送者消息的接受者要發(fā)送的以太幣的數(shù)量可選的數(shù)據(jù)(合約的參數(shù))STARTGAS:用來(lái)限制合約最多執(zhí)行多少次運(yùn)算調(diào)用合約的CALL方法時(shí)隱式生成2021/6/278以太坊狀態(tài)轉(zhuǎn)移2021/6/279以太坊的狀態(tài)轉(zhuǎn)換函數(shù):APPLY(S,TX)->S’,可以定義如下:1.檢查交易的格式是否正確(即有正確數(shù)值)、簽名是否有效和隨機(jī)數(shù)是否與發(fā)送者賬戶的隨機(jī)數(shù)匹配。如否,返回錯(cuò)誤。2.計(jì)算交易費(fèi)用:fee=STARTGAS*GASPRICE,并從簽名中確定發(fā)送者的地址。從發(fā)送者的賬戶中減去交易費(fèi)用和增加發(fā)送者的隨機(jī)數(shù)。如果賬戶余額不足,返回錯(cuò)誤。3.設(shè)定初值GAS=STARTGAS,并根據(jù)交易中的字節(jié)數(shù)減去一定量的燃料值。4.從發(fā)送者的賬戶轉(zhuǎn)移價(jià)值到接收者賬戶。如果接收賬戶還不存在,創(chuàng)建此賬戶。如果接收賬戶是一個(gè)合約,運(yùn)行合約的代碼,直到代碼運(yùn)行結(jié)束或者燃料用完。5.如果因?yàn)榘l(fā)送者賬戶足夠的錢或者代碼執(zhí)行耗盡燃料導(dǎo)致價(jià)值轉(zhuǎn)移失敗,生成out-of-gas異常,恢復(fù)原來(lái)的狀態(tài),但是還需要支沒(méi)有付交易費(fèi)用,交易費(fèi)用加至礦工賬戶。6.否則,將所有剩余的燃料歸還給發(fā)送者,消耗掉的燃料作為交易費(fèi)用發(fā)送給礦工。以太坊狀態(tài)轉(zhuǎn)移函數(shù)2021/6/2710以太坊有Go語(yǔ)言、C++語(yǔ)言、Python語(yǔ)言的版本。以太坊實(shí)現(xiàn)版本2021/6/2711Etherscan以太坊區(qū)塊在線瀏覽https://etherscan.io/2021/6/2712以太坊的問(wèn)題挖礦機(jī)制高耗能每秒10~20筆交易并發(fā)處理能力差完全公開(kāi)

隱私性交易費(fèi)用小額交易成本高以太坊在不斷的改進(jìn)中,很多機(jī)制可能會(huì)改變。2021/6/2713Part2智能合約2021/6/2714智能合約的定義Smartcontractsarepiecesofcodethatliveontheblockchainandexecutecommandsexactlyhowtheweretoldto.智能合約就是存儲(chǔ)在區(qū)塊鏈上的代碼,用以實(shí)現(xiàn)執(zhí)行特定的功能。“智能合約”-根據(jù)事先任意制訂的規(guī)則來(lái)自動(dòng)轉(zhuǎn)移數(shù)字資產(chǎn)的系統(tǒng)。業(yè)務(wù)人員開(kāi)發(fā)人員2021/6/2715智能合約使用步驟編譯合約部署合約調(diào)用合約監(jiān)聽(tīng)合約銷毀合約創(chuàng)建合約2021/6/2716編譯合約備注:本節(jié)中的所有例子以在Go語(yǔ)言的客戶端geth中的操作為例vargreeterSource='contractgreeterismortal{stringgreeting;…..returngreeting;}}'

vargreeterCompiled=pile.solidity(greeterSource)

contractgreeterismortal{//繼承mortal

stringgreeting;

functiongreeter(string_greeting)public{greeting=_greeting;}

functiongreet()constantreturns(string){returngreeting;}}

智能合約helloword2021/6/2717創(chuàng)建合約備注:本節(jié)中的所有例子以在Go語(yǔ)言的客戶端geth中的操作為例vargreeterContract=web3.eth.contract(greeterCompiled["<stdin>:greeter"].info.abiDefinition);

abiDefinition是合約的接口說(shuō)明老版本中是greeterC.abiDefinition新版本(geth-1.5.9)中是greeterCompiled["<stdin>:greeter"].info.abiDefinition2021/6/2718部署合約vargreeter=greeterContract.new(_greeting,{from:eth.accounts[0],data:greeterCompiled["<stdin>:greeter"].code,gas:1000000},function(e,contract){if(!e){if(!contract.address){console.log("Contracttransactionsend:TransactionHash:"+contract.transactionHash+"waitingtobemined...");}else{console.log("Contractmined!Address:"+contract.address);console.log(contract);}}})部署合約的時(shí)候,需要支付費(fèi)用,需要用戶輸入密碼,先執(zhí)行personal.unlockAccount(eth.accounts[0]);日志2021/6/2719調(diào)用合約合約部署的Transaction被礦工挖礦之后,可以調(diào)用該合約。greeter.greet()

合約部署的Transaction被礦工挖礦之后,可以查看該合約的地址。eth.getCode(greeter.address))2021/6/2720其它的機(jī)器調(diào)用合約其它的機(jī)器上沒(méi)有g(shù)reeter對(duì)象,需要根據(jù)合約的地址和abiDefinition來(lái)創(chuàng)建,然后調(diào)用。vargreeter2=eth.contract([{constant:false,inputs:[],name:‘kill’,outputs:[],type:‘function’},{constant:true,inputs:[],name:‘greet’,outputs:[{name:‘’,type:‘string’}],type:‘function’},{inputs:[{name:‘_greeting’,type:‘string’}],type:'constructor'}]).at(‘0xcde7cfdf234dfa63ba4d7c273a’);greeter2.greet();2021/6/2721監(jiān)聽(tīng)合約合約部署后,可設(shè)置監(jiān)聽(tīng)另一種調(diào)用方式2021/6/2722銷毀合約只有擁有者才能銷毀合約msg存在于上下文中,不是參數(shù)中2021/6/2723合約使用場(chǎng)景對(duì)沖合約、儲(chǔ)蓄錢包、遺囑等金融類場(chǎng)景在線投票、去中心化治理、域名注冊(cè)非金融類場(chǎng)景2021/6/2724DAPPS(去中心化的應(yīng)用)/上面已經(jīng)有300300多個(gè)DAPPS2021/6/2725DAPPS2021/6/2726構(gòu)建去中心化WEB3.02021/6/2727Solidity語(yǔ)言Part32021/6/2728數(shù)據(jù)類型DatalocationArraysStructs引用類型Mappingsmapping(_KeyType

=>

_ValueType)不能遍歷keys和valuesboolean,int/uint,byte,string,enumInt8~int256bytes1,bytes2,…bytes32function,fixedpointnumbers基本類型20個(gè)字節(jié),主要方法:balance、transfer、send、call、delegatecall、callcodeaddress2021/6/2729流程控制和函數(shù)支持大部分javascript的邏輯控制,包括if,

else,

while,

do,

for,

break,

continue,

return,

?

:

但是不支持switch和gotofunction

函數(shù)名(參數(shù))

權(quán)限控制符returns(返回值,可以有多個(gè))functionRegister(uintinitialPrice){price=initialPrice;}functionutterance()returns(bytes32){return

"miaow";}functiongetData()public

returns(uint){returndata;}

2021/6/2730合約的結(jié)構(gòu)合約與面向?qū)ο缶幊讨械念惙浅O嗨啤:霞s由變量、函數(shù)、函數(shù)修飾符、事件、struct結(jié)構(gòu)體、枚舉類型構(gòu)成。合約也可以繼承。2021/6/2731函數(shù)的修飾符可見(jiàn)性:public,private,internal,external。其中public和private用于決定是否可以通過(guò)對(duì)象直接調(diào)用。internal和external用于決定是否其它的合約可以調(diào)用。另外constant關(guān)鍵詞,可以用于修飾常量和常函數(shù)。2021/6/2732事件Event——非常重要的功能以太坊通過(guò)Logs實(shí)現(xiàn)Events(事件)功能。日志內(nèi)容是交易收據(jù)(TransactionReceipts)的一部分,整個(gè)日志內(nèi)容,包括Receipts的其它內(nèi)容會(huì)生成一個(gè)ReceiptsRoot存儲(chǔ)在區(qū)塊的頭部。日志永遠(yuǎn)存在。通過(guò)設(shè)置一些過(guò)濾條件,來(lái)獲取某些特定的事件。可以用于追溯合約的歷史狀態(tài),設(shè)置檢查點(diǎn)等。event

Deposit(address

indexed_from,bytes32

indexed_id,uint_value);

2021/6/2733繼承抽象合約接口contractFinalisBase2,Base1{}繼承的關(guān)鍵字是is,支持多重繼承。2021/6/2734常用對(duì)象和操作2021/6/2735編譯器和開(kāi)發(fā)環(huán)境IDE1、IntelliJIDEAplugin2、VisualStudioExtension等其他/#version=soljson-v0.4.10+commit.f0d539ae.jsOnlie編譯器是solc2021/6/2736Part4Demo演示2021/6/2737本地區(qū)塊鏈網(wǎng)絡(luò)的部署區(qū)塊鏈初始化,為賬戶分配以太幣{“nonce”:“0x0000000000000042”,"mixhash":"0x00000000000000000000000000000000000000000000000000000000","difficulty":"0x4000",//難度值,決定塊生成的速度"alloc":{"0x09c7b615a1c5b3016ff6b521723364aa9382ec6e":

{“balance”:“10000000000000000000”}},//10個(gè)以太幣"c

溫馨提示

  • 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論