A. 怎麼向小狐狸錢包充值
安裝MetaMask錢包有兩種方法:
一、MetaMask使用方法:
1、點擊右上角的「小狐狸」。
2、閱讀並同意MetaMask條款和注意事項。
3、點擊「創建新錢包」。當然你也可以選擇下面一項導入已有錢包。
4、設置密碼,然後點擊「ok」。
5、: Metamask會為您創建12個英文助記詞,這非常重要您必須准確。
6、點擊「我已經備份助記詞並安全保存」,您的錢包就創建成功了。
二、PART C - 轉換為主網和錢包充值:
1、點擊「現行測試主網」。
2、選擇「以太坊主網」。
3、MetaMask 會讓您輸入密碼,輸入完成然後點擊「解鎖」。
4、點擊復制的標志獲取您的錢包地址,然後你可以把eth或其他erc20的資產打入這個地址。就可以錢包充值。
操作環境:華為手機nova4 5.6.0 網路APP 版型號:3.0.497
拓展資料:
1、數字錢包是:
數字錢包是一種能使用戶在Web網上支付貨款的軟體。它保存信用卡號碼和其它個人信息,如送貨地址。數據一旦被輸入,就自動轉移到商家網站的訂貨域。
使用數字錢包時,當消費者購買物品時,不需要填寫每個站點上的訂單,因為信息已經存儲了,並自動更新和進入到廠商站點的訂貨域。
2、分類:
數字錢包分兩大類型:客戶端和伺服器端(數字錢包)。在這些分類中是那些只在某些商家網站上工作的錢包和那些商家不可知的錢包。
基於客戶的數字錢包是兩種錢包中較陳舊的一種,據分析人士稱,這類錢包已開始沒人理睬了,因為它們要求用戶下載和安裝軟體。用戶下載錢包的應用程序和輸入付款額和郵寄信息。在這個意義上,信息是安全的,並在用戶的硬碟上進行了加密。用戶在本地獲得對其信用卡和個人信息的控制。
使用基於伺服器的錢包時,用戶填寫其個人信息,並自動下載點心文件(點心文件是一個包括了有關用戶信息的文本文件)。在這種情況下,消費者的信息駐留在金融機構或者數字錢包供應商的伺服器上,而不是用戶的PC機上。
3、數字錢包的功能有:
數字錢包是一種能使用戶在Web網上支付貨款的軟體。它保存信用卡號碼和其它個人信息,如送貨地址。數據一旦被輸入,就自動轉移到商家網站的訂貨域。
使用數字錢包時,當消費者購買物品時,不需要填寫每個站點上的訂單,因為信息已經存儲了,並自動更新和進入到廠商站點的訂貨域。消費者使用數字錢包時也能得到好處,因為他們的信息被加密了,即由私人軟體代碼加以保護。商家也避免了受騙而得到保護,也從中獲益。
B. 選擇以太坊客戶端
有很多以太坊客戶端供我們選擇。我們推薦在開發和部署時使用不同的客戶端。
我們推薦 Ganache ,它是一個運行在你個人電腦上的私有連客戶端。它是 truffle 套種中的一部分,
Ganache 將智能合約和交易放在前台並且中心化,從而簡化了dapp的開發。使用 Ganache 你可以
快速查看你們的應用是如何影響區塊鏈的,並且對賬戶,余額,智能合約創建以及燃料消費進行自省。
Ganache 運行在 http://127.0.0.1:7545 。默認會創建是個賬戶,重啟後賬戶依然不會變,
當然也可以手動隨機賬戶,你也可以用你自己的賬戶。
我們同樣也推薦使用 truffle develop ,它是 truffle 內置的開發鏈工具。不需要任何的額外安裝,
你要使用它只需要一條命令行即可:
Truffle Develop 運行在 http://127.0.0.1:9545 上。
當你的開發機沒有圖形界面時就無法直接使用 Ganache ,而 Ganache CLI 就提供了沒有圖形界面系統的能力。
有很多官方和非官網的以太坊客戶端你可以選擇。以下是部分:
C. 怎麼接以太坊公鏈
建立連接以接儒以太坊公鏈。
一、1、以太坊客戶端下載,注意:需翻牆,下載版本為1.8.23-stable,否則可能出現與以太坊錢包客戶端存在不匹配問題。
2、以太坊錢包客戶端下載。
3、安裝以太坊客戶端。
二、私有鏈創建:創建創世區塊。
三、安裝並啟動以太坊錢包客戶端。
D. ENYC是什麼
ENYC
能鏈鏈(英文Energy chain)是一個開源的有智能合約功能的公共區塊鏈平台,通過其專用加密貨幣(ENYC)提供去中心化的虛擬機(「能量虛擬機」 Energy Virtual Machine)來處理點對點合約。
中文名:能量鏈;
屬性:區塊鏈大健康平台;
外文名:Energy chain;
創始人:John Charles
產生背景
比特幣開創了去中心化密碼貨幣的先河,五年多的時間充分檢驗了區塊鏈技術的可行性和安全性。比特幣的區塊鏈事實上是一套分布式的資料庫,如果再在其中加進一個符號——比特幣,並規定一套協議使得這個符號可以在資料庫上安全地轉移,並且無需信任第三方,這些特徵的組合完美地構造了一個貨幣傳輸體系——比特幣網路。
以太坊基於比特幣網路擁堵所開發的區塊鏈,且創建了基於區塊鏈底層技術的平台。程序安裝在這個虛擬機系統運行,如果是一台虛擬機和現在的也沒太大區別,但是整個以太坊系統是可以由全球任何計算機加入到這個體系了,每台電腦只要安裝了以太坊客戶端就可以成為以太坊的一個節點一個虛擬機,所以整個以太坊系統未來規模再發展的話,可以說是全球超級計算機系統,人人都可以開發程序放在這個超級計算機運行。再說一點,這種模式的優點,現在的都是集中的雲伺服器,中心化的,可能有幾個備份,但是一旦壞死,就不能運行,但是點對點的網路特點就是,就算幾個節點下線了,或者被攻擊了,有一部分在運行整個系統還是可以運行,抗風險抗錯性很高。
EOS通過創建一個對開發者友好的區塊鏈底層平台,類似區塊鏈的操作系統,性能強大,可以支持多個應用程序同時運,可以同時支持多種編程語言,為開發dapp的開發者提供底層模塊,降低開發門檻。
機遇比特幣,以太坊,EOS都是機遇行業的基礎建設,未能實現有效的應用。
ENYC基於大健康領域所開發的行業區塊鏈底層平台,類似於大健康行業的底層操作系統。ENYC的核心演算法為Ethash(Dagger-Hashimoto 演算法的改良版本),包括找到演算法的隨機數輸入 以使結果低於特定的難度閥值。要找到這樣一個隨機數,沒有比列舉可能性更好的策略,而解決方法的驗證瑣 碎又廉價。由於輸出有均勻分布(是散表功能應用的結果),我們可以保證,平均而言,需要找到這樣一 個隨機數的時間取決於難度閥值。這使得只通過操縱難度來控制找到新區塊的時間成為可能。
設計原則
簡潔原則
ENYC協議將盡可能簡單,即便以某些數據存儲和時間上的低效為代價。一個普通的程序員也能夠完美地去實現完整的開發說明。這將最終有助於降低任何特殊個人或精英團體可能對協議的影響並且推進ENYC作為對所有人開放的協議的應用前景。添加復雜性的優化將不會被接受,除非它們提供了非常根本性的益處。
通用原則
沒有「特性」是ENYC設計哲學中的一個根本性部分。取而代之的是,ENYC提供了一個健康產業內部的圖靈完備的腳本語言以供用戶來構建任何可以精確定義的智能合約或交易類型。想建立一個全規模的守護程序(Daemon)或天網(Skynet),你可能需要幾千個聯鎖合約並且確定慷慨地喂養它們,一切皆有可能。
模塊化原則
ENYC的不同部分應被設計基於大健康行業模塊化的和可分的。開發過程中,應該能夠容易地讓在協議某處做一個小改動的同時應用層卻可以不加改動地繼續正常運行。以太坊開發應該最大程度地做好這些事情以助益於整個加密貨幣生態系統,而不僅是自身。
無歧視原則
協議不應主動地試圖限制或阻礙特定的類目或用法,協議中的所有監管機制都應被設計為直接監管危害,不應試圖反對特定的不受歡迎的應用。人們甚至可以在ENCY之上運行一個無限循環腳本,只要他願意為其支付按計算步驟計算的交易費用。
功能應用
ENYC是一個基於大健康產業平台,它上面提供各種模塊讓用戶來搭建應用,如果將搭建行業應用比作造房子,那麼ENYC就提供了牆面、屋頂、地板等模塊,用戶只需像搭積木一樣把房子搭起來,因此在ENYC上建立應用的成本和速度都大大改善。具體來說,ENYC通過一套圖靈完備的腳本語言(EnergyVirtual Machinecode,簡稱EVM語言)來建立應用,它類似於匯編語言,我們知道,直接用匯編語言編程是非常痛苦的,但ENYC里的編程並不需要直接使用EVM語言,而是類似C語言、Python、Lisp等高級語言,再通過編譯器轉成EVM語言。
上面所說的平台之上的應用,其實就是合約,這是ENYC的核心。合約是一個活在ENYC系統里的自動代理人,他有一個自己的ENYC-Coin地址,當用戶向合約的地址里發送一筆交易後,該合約就被激活,然後根據交易中的額外信息,合約會運行自身的代碼,最後返回一個結果,這個結果可能是從合約的地址發出另外一筆交易。需要指出的是,ENYC中的交易,不單只是發送ENYC而已,它還可以嵌入相當多的額外信息。如果一筆交易是發送給合約的,那麼這些信息就非常重要,因為合約將根據這些信息來完成自身的業務邏輯。
合約所能提供的業務,幾乎是無窮無盡的,它的邊界就是你的想像力,因為圖靈完備的語言提供了完整的自由度,讓用戶搭建大健康行業各種應用。
E. ETH以太坊核心開發者會議第92期,會議講了哪些主要內容
ETH以太坊核心開發者會議主要內容大致如下:凱特·赫德逐漸協助開展一些調研,並將調研的連接貼上,表明了調研的內容。他表明期待根據調研得到一些數據信息。比如,在調查問卷中提及,假如必須別的遠程伺服器,客戶最期待挑選哪一個。數據信息意見反饋說明Besu是最好是的備用胎。但在她們傳出調查研究報告以前,她們還不上一個星期,她們期待獲得大量的數據信息。
阿萊克西號召大量人參加進去,以掌握大家如今評定難題的方式是不是不善。提姆提了個小提議。他知道大家有一個交換目錄,還有一個挖礦軟體,這些,他提議大夥兒能夠把這個文件目錄訪問 一遍,看一下用是多少佔比。普賈說早已擁有這一明細,已經考慮到當中。喬治願意現階段的評價方法,並提議能夠應用公布在EthDiscovery上的ENR數據信息。此數據信息是以前網路爬蟲信息內容獲得的,包含ENR安裝的手機客戶端總數,ENR中是不是有ENR實際手機客戶端信息內容這些。阿萊克西覺得,他更趨向於手工製作方式。他覺得自動化技術調節能夠得到數據信息,但沒法告訴你某一連接點的必要性。針對某一連接點的必要性,及其一旦該連接點不成功或發生的共識無效的難題,大家並不清楚它將產生多少的沖擊性。有多少連接點不可以工作中,我們可以了解,可是不清楚它將造成哪些結果。喬治問Peter是不是了解ENR信息內容是功能完善的或是輕形遠程伺服器的。皮特覺得,這類必須分狀況不可以一概而論。
阿萊克西注重,在開展調研時,大家還務必重視客戶的私人信息,這一方面很重要,另一方面也是為了更好地防止客戶因擔憂隱私保護而不可以精確解答問題。普賈說,如今全部的信息內容都存有excel表,她們不容易與群眾共享資源。在考慮到私人信息的狀況下,一些難題被設計方案為可挑選的。阿萊克西問隱私保護數據泄露的不良影響是啥,馬庫斯莫里斯回應說,如果有挖礦共享資源硬體配置機器設備信息內容,就很有可能造成 DDoS對於她們的進攻,尤其是應用別的顧客的競爭者。他感覺這並不一定會產生,它是很有可能的。
ETH以太坊核心開發者會議第92期,會議講了哪些主要內容?
有關調研數據信息,Alexey明確提出的另一個難題是,是不是能夠按時發布調查報告,例如每月發布一次?因為他了解到一些作業者一直把Geth視作流行,從來沒有想過要更改以往。倘若我們可以根據數據信息的展現告知她們,事實上大家應當做些哪些來改進現況。他們還能夠從商業服務層面,及其他們可否項目投資是多少以改進這一管理體系的水平上開展評定,並從這當中獲利。只願過去了好多個月,大家會見到新數據的一些轉變。胡德森完全同意。
傑姆斯不同意,他覺得從他自己的工作經驗看來,他感覺難以從連接點營運商那邊得到恰當的信息內容。即便大家獲得了恰當的數據信息,要更改連接點那裡的情況也十分艱難。阿萊克西覺得,如今沒人來融洽全部系統軟體,每一個人都從自身的視角或從本身運營模式的利潤最大化視角來考慮到難題。蒂姆明確提出了一個見解,即如果我們必須使顧客多元化,大家應當根據調研找到想要應用不一樣顧客客戶或連接點營運商的相同點,隨後小結出這種相同點並不斷發展。
阿萊克西說,假如對調研和調研數據信息沒有一切附加的建議,他還想再提一個難題。最初,當他想起這個問題時,他覺得凱特·赫德斯能幫上忙。在他來看,這些人手上都是有一張有關工作人員的名冊,選用采訪並非調研的方式,比如電話調研,那樣能夠更迅速、更合理地掌握每一個人的念頭。蒂姆表明,它是對調研的一個非常好的填補。阿萊克西再次說,假如大家都願意調研的方式,那麼就必須一位助理員來保證 大夥兒的觀念一致,另外還要保證 生態鏈的每一個角落裡都能獲得恰當的信息內容。
ETH以太坊核心開發者會議第92期,會議講了哪些主要內容?
維塔利克說,事實上這里有2個難題,一個是短期內的難題,誰在進攻互聯網,一個是長期性的難題,互聯網的經營規模在不斷發展。皮特他抵制把gas限定提升 。假如讓互聯網再次擴大得話,可能引起比較嚴重的難題。依據上一次蘇州地區黑客攻擊的工作經驗,網路攻擊是先讓互聯網澎漲,讓以太坊互聯網不斷發展,隨後根據各種各樣方法進攻連接點。在那個時候,有二種解決方法,一種是推升成本費,讓網路攻擊沒法壓力讓互聯網澎漲提升的成本費,另一種是立即刪掉提升的一部分網路語言暴力。倘若大家如今決策提升gas極限,那麼互聯網的經營規模可能漸漸地提升,假如提升到一個風險的極限情況,大家將刪不掉任何東西,大家將束手無策。大家確實必須因此憂慮一下。在同歩角上也會發生難題。當互聯網尺寸翻倍時,系統軟體同歩需要的時間將提升大量,並非同歩翻倍。詹姆士問皮特,是不是有一些解決方法非常值得考慮到?
阿萊克西表明,如今得出一個詳細的解決方法很有可能過早了,並且現階段都還沒充足的時間來全方位考慮到一切解決方法的提議。實際上,上一次大會上,他說道有一點小矛盾,一些人覺得寫一個詳細的以太坊手機客戶端是很艱難的,因而大家明確提出why。然後,紀錄了四個回答。其一是協議書過度繁雜,無法將編碼分層次模塊化設計。可是Alexey卻覺得,實際上,大家並沒有在一開始就設計方案好編碼。如今的手機軟體模塊化設計幹了許多工作中,那樣就非常容易完成不一樣的人維護保養不一樣的手機軟體控制模塊。但他猜疑是不是每一個人都是有那樣的念頭,都想要那麼做,是不是有那麼多的人想要資金投入這么多資源,或是要直到Eth2.0?
皮特表述說,的確有很多人覺得Eth2.0是一種解決方法,但他要想回應的是,Eth2.0的確提升 了貨運量,但並沒有解決困難,因此Eth2.0並不是解決方法,它僅僅增加了難題的曝露時間。Alexey表明,他的聚焦點沒有技術性,而在構架和機構。可否創建一個軟體體系結構精英團隊,該精英團隊是不是可以在Eth2.0精英團隊中開始工作。如果沒有得話,Eth2.0是否會喪失模塊化設計手機軟體的機遇?皮特說Eth2.0。
#數字貨幣# #比特幣[超話]#
F. 區塊鏈和智能合約,以太坊開發,183位開發者整理,知識體系匯總
在以太坊上開發應用程序的可用工具、組件、模式和平台的指南。
此列表的創建是由 ConsenSys 的產品經理推動的,他們認為需要在新的和有經驗的區塊鏈開發人員之間更好地共享工具、開發模式和組件。
開發智能合約
智能合約語言
構架
IDE
其他工具
測試區塊鏈網路
測試以太水龍頭
前端以太坊 API
後端以太坊 API
引導程序/開箱即用工具
以太坊 ABI(應用程序二進制介面)工具
以太坊客戶端
貯存
Mahuta - 具有附加搜索功能的 IPFS 存儲服務,以前稱為 IPFS-Store
OrbitDB - IPFS 之上的去中心化資料庫
JS IPFS API - IPFS HTTP API 的客戶端庫,用 JavaScript 實現
TEMPORAL - 易於使用的 API 到 IPFS 和其他分布式/去中心化存儲協議
PINATA - 使用 IPFS 的最簡單方法
消息傳遞
測試工具
安全工具
監控
其他雜項工具
Cheshire - CryptoKitties API 和智能合約的本地沙箱實現,可作為 Truffle Box 使用
ERCs-以太坊評論請求存儲庫
ERC-20 - 可替代資產的原始令牌合約
ERC-721 - 不可替代資產的令牌標准
ERC-777 - 可替代資產的改進令牌標准
ERC-918 - 可開采令牌標准
流行的智能合約庫
可擴展性
支付/狀態通道
等離子體
側鏈
POA橋
POA 橋用戶界面
POA 橋梁合同
ZK-SNARK
ZK-STARK
預構建的 UI 組件
以上內容,來自git庫:
github.com/ConsenSys/ethereum-developer-tools-list
我是魚歌,一個在深圳創業的全棧程序員,主攻區塊鏈,元宇宙和智能合約,附加小程序和app開發。
[祈禱]
G. DApp開發入門
本文僅介紹以太坊系列的DApp開發,其他鏈原理差不太多。
MetaMask安裝完成並運行後,可以在Chrome控制台列印 MetaMask注入的window.ethereum對象
關於ethereum對象,我們只需要關心 ethereum.request 就足夠了,MetaMask 使用 ethereum.request(args) 方法 來包裝 RPC API。這些 API 基於所有以太坊客戶端公開的介面。 簡單來說錢包交互的大部分操作都是由 request() 方法實現,通過傳入不同的方法名來區分。
⚠️ 即使ethereum對象中提供了chainId,isMetaMask,selectAddress屬性,我們也不能完全相信這些屬性,他們是不穩定或不標准,不建議使用。我們可以通過上面說的request方法,拿到可靠的數據 。
錢包通過method方法名,進行對應的實現 以獲取錢包地址為例
調用 ethereum.request({ method: "eth_requestAccounts" }) ,錢包實現了該方法,那麼就可以拿到錢包的地址了。
MetaMask注入的 window.ethereum 就是一個Provider,一個RPC節點也是一個Provider,通過Provider,我們有了訪問區塊鏈的能力。 在連接到錢包的情況下,通常使用錢包的Provider就可以了, ethers.providers.Web3Provider(ethereum)
如果只需要查詢一些區塊鏈數據,可以使用EtherscanProvider 和 InfuraProvider 連接公開的 第三方節點服務提供商 。JsonRpcProvider 和 IpcProvider 允許連接到我們控制或可以訪問的以太坊節點。
獲取當前賬戶余額
獲取最新區塊號
其他RPC操作,可以通過 JSON-RPC 查看。
通過 ethers.js 可以連接ERC20的合約,合約編譯後會生成ABI,合約部署後,會生成合約地址,開發者通過 ABI和合約地址 ,對合約發送消息。
合約中的方法大致分為兩種: 視圖方法(免費),非視圖方法(消耗Gas) ,可以通過ABI查看方法類型。
⚠️ ERC20需要多加關注的是 Approve() 方法以及 transfer() 和 transferFrom() 的區別 ,授權過的代幣,被授權的那一方,可以通過調用 transferFrom() 方法,轉走你授權數量內的代幣,所以授權是一個很危險的操作,假設你授權了一個不良的合約,那你會面臨授權的token被轉走的風險,即使你沒有泄露私鑰助記詞。
便利三方庫: web3-react use-wallet
文檔: doc.metamask.io ethers
H. 以太坊是什麼丨以太坊開發入門指南
以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(Ethereum)是一個建立在區塊鏈技術之上, 去中心化應用平台。它允許任何人在平台中建立和使用通過區塊鏈技術運行的去中心化應用。
對這句話不理解的同學,姑且可以理解為以太坊是區塊鏈里的Android,它是一個開發平台,讓我們就可以像基於Android Framework一樣基於區塊鏈技術寫應用。
在沒有以太坊之前,寫區塊鏈應用是這樣的:拷貝一份比特幣代碼,然後去改底層代碼如加密演算法,共識機制,網路協議等等(很多山寨幣就是這樣,改改就出來一個新幣)。
以太坊平台對底層區塊鏈技術進行了封裝,讓區塊鏈應用開發者可以直接基於以太坊平台進行開發,開發者只要專注於應用本身的開發,從而大大降低了難度。
目前圍繞以太坊已經形成了一個較為完善的開發生態圈:有社區的支持,有很多開發框架、工具可以選擇。
智能合約
什麼是智能合約
以太坊上的程序稱之為智能合約, 它是代碼和數據(狀態)的集合。
智能合約可以理解為在區塊鏈上可以自動執行的(由事件驅動的)、以代碼形式編寫的合同(特殊的交易)。
在比特幣腳本中,我們講到過比特幣的交易是可以編程的,但是比特幣腳本有很多的限制,能夠編寫的程序也有限,而以太坊則更加完備(在計算機科學術語中,稱它為是「圖靈完備的」),讓我們就像使用任何高級語言一樣來編寫幾乎可以做任何事情的程序(智能合約)。
智能合約非常適合對信任、安全和持久性要求較高的應用場景,比如:數字貨幣、數字資產、投票、保險、金融應用、預測市場、產權所有權管理、物聯網、點對點交易等等。
目前除數字貨幣之外,真正落地的應用還不多(就像移動平台剛開始出來一樣),相信1到3年內,各種殺手級會慢慢出現。
編程語言:Solidity
智能合約的默認的編程語言是Solidity,文件擴展名以.sol結尾。
Solidity是和JavaScript相似的語言,用它來開發合約並編譯成以太坊虛擬機位元組代碼。
還有長像Python的智能合約開發語言:Serpent,不過建議大家還是使用Solidity。
Browser-Solidity是一個瀏覽器的Solidity IDE, 大家可以點進去看看,以後我們更多文章介紹Solidity這個語言。
運行環境:EVM
EVM(Ethereum Virtual Machine)以太坊虛擬機是以太坊中智能合約的運行環境。
Solidity之於EVM,就像之於跟JVM的關系一樣,這樣大家就容易理解了。
以太坊虛擬機是一個隔離的環境,在EVM內部運行的代碼不能跟外部有聯系。
而EVM運行在以太坊節點上,當我們把合約部署到以太坊網路上之後,合約就可以在以太坊網路中運行了。
合約的編譯
以太坊虛擬機上運行的是合約的位元組碼形式,需要我們在部署之前先對合約進行編譯,可以選擇Browser-Solidity Web IDE或solc編譯器。
合約的部署
在以太坊上開發應用時,常常要使用到以太坊客戶端(錢包)。平時我們在開發中,一般不接觸到客戶端或錢包的概念,它是什麼呢?
以太坊客戶端(錢包)
以太坊客戶端,其實我們可以把它理解為一個開發者工具,它提供賬戶管理、挖礦、轉賬、智能合約的部署和執行等等功能。
EVM是由以太坊客戶端提供的。
Geth是典型的開發以太坊時使用的客戶端,基於Go語言開發。 Geth提供了一個互動式命令控制台,通過命令控制台中包含了以太坊的各種功能(API)。Geth的使用我們之後會有文章介紹,這里大家先有個概念。
Geth控制台和Chrome瀏覽器開發者工具里的面的控制台是類似,不過是跑在終端里。
相對於Geth,Mist則是圖形化操作界面的以太坊客戶端。
如何部署
智能合約的部署是指把合約位元組碼發布到區塊鏈上,並使用一個特定的地址來標示這個合約,這個地址稱為合約賬戶。
以太坊中有兩類賬戶:
· 外部賬戶
該類賬戶被私鑰控制(由人控制),沒有關聯任何代碼。
· 合約賬戶
該類賬戶被它們的合約代碼控制且有代碼與之關聯。
和比特幣使用UTXO的設計不一樣,以太坊使用更為簡單的賬戶概念。
兩類賬戶對於EVM來說是一樣的。
外部賬戶與合約賬戶的區別和關系是這樣的:一個外部賬戶可以通過創建和用自己的私鑰來對交易進行簽名,來發送消息給另一個外部賬戶或合約賬戶。
在兩個外部賬戶之間傳送消息是價值轉移的過程。但從外部賬戶到合約賬戶的消息會激活合約賬戶的代碼,允許它執行各種動作(比如轉移代幣,寫入內部存儲,挖出一個新代幣,執行一些運算,創建一個新的合約等等)。
只有當外部賬戶發出指令時,合同賬戶才會執行相應的操作。
合約部署就是將編譯好的合約位元組碼通過外部賬號發送交易的形式部署到以太坊區塊鏈上(由實際礦工出塊之後,才真正部署成功)。
運行
合約部署之後,當需要調用這個智能合約的方法時只需要向這個合約賬戶發送消息(交易)即可,通過消息觸發後智能合約的代碼就會在EVM中執行了。
Gas
和雲計算相似,佔用區塊鏈的資源(不管是簡單的轉賬交易,還是合約的部署和執行)同樣需要付出相應的費用(天下沒有免費的午餐對不對!)。
以太坊上用Gas機制來計費,Gas也可以認為是一個工作量單位,智能合約越復雜(計算步驟的數量和類型,佔用的內存等),用來完成運行就需要越多Gas。
任何特定的合約所需的運行合約的Gas數量是固定的,由合約的復雜度決定。
而Gas價格由運行合約的人在提交運行合約請求的時候規定,以確定他願意為這次交易願意付出的費用:Gas價格(用以太幣計價) * Gas數量。
Gas的目的是限制執行交易所需的工作量,同時為執行支付費用。當EVM執行交易時,Gas將按照特定規則被逐漸消耗,無論執行到什麼位置,一旦Gas被耗盡,將會觸發異常。當前調用幀所做的所有狀態修改都將被回滾, 如果執行結束還有Gas剩餘,這些Gas將被返還給發送賬戶。
如果沒有這個限制,就會有人寫出無法停止(如:死循環)的合約來阻塞網路。
因此實際上(把前面的內容串起來),我們需要一個有以太幣余額的外部賬戶,來發起一個交易(普通交易或部署、運行一個合約),運行時,礦工收取相應的工作量費用。
以太坊網路
有些著急的同學要問了,沒有以太幣,要怎麼進行智能合約的開發?可以選擇以下方式:
選擇以太坊官網測試網路Testnet
測試網路中,我們可以很容易獲得免費的以太幣,缺點是需要發很長時間初始化節點。
使用私有鏈
創建自己的以太幣私有測試網路,通常也稱為私有鏈,我們可以用它來作為一個測試環境來開發、調試和測試智能合約。
通過上面提到的Geth很容易就可以創建一個屬於自己的測試網路,以太幣想挖多少挖多少,也免去了同步正式網路的整個區塊鏈數據。
使用開發者網路(模式)
相比私有鏈,開發者網路(模式)下,會自動分配一個有大量余額的開發者賬戶給我們使用。
使用模擬環境
另一個創建測試網路的方法是使用testrpc,testrpc是在本地使用內存模擬的一個以太坊環境,對於開發調試來說,更方便快捷。而且testrpc可以在啟動時幫我們創建10個存有資金的測試賬戶。
進行合約開發時,可以在testrpc中測試通過後,再部署到Geth節點中去。
更新:testrpc 現在已經並入到Truffle 開發框架中,現在名字是Ganache CLI。
Dapp:去中心化的應用程序
以太坊社區把基於智能合約的應用稱為去中心化的應用程序(DecentralizedApp)。如果我們把區塊鏈理解為一個不可篡改的資料庫,智能合約理解為和資料庫打交道的程序,那就很容易理解Dapp了,一個Dapp不單單有智能合約,比如還需要有一個友好的用戶界面和其他的東西。
Truffle
Truffle是Dapp開發框架,他可以幫我們處理掉大量無關緊要的小事情,讓我們可以迅速開始寫代碼-編譯-部署-測試-打包DApp這個流程。
總結
我們現在來總結一下,以太坊是平台,它讓我們方便的使用區塊鏈技術開發去中心化的應用,在這個應用中,使用Solidity來編寫和區塊鏈交互的智能合約,合約編寫好後之後,我們需要用以太坊客戶端用一個有餘額的賬戶去部署及運行合約(使用Truffle框架可以更好的幫助我們做這些事情了)。為了開發方便,我們可以用Geth或testrpc來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。