1. 如何創建和簽署以太坊交易
交易
區塊鏈交易的行為遵循不同的規則集
由於公共區塊鏈分布式和無需許可的性質,任何人都可以簽署交易並將其廣播到網路。
根據區塊鏈的不同,交易者將被收取一定的交易費用,交易費用取決於用戶的需求而不是交易中資產的價值。
區塊鏈交易無需任何中央機構的驗證。僅需使用與其區塊鏈相對應的數字簽名演算法(DSA)使用私鑰對其進行簽名。
一旦一筆交易被簽名,廣播到網路中並被挖掘到網路中成功的區塊中,就無法恢復交易。
以太坊交易結構
以太坊交易的數據結構:交易0.1個ETH
{這些數據與交易內容無關,與交易的執行方式有關,這是由於在以太坊中發送交易中,您必須定義一些其他參數來告訴礦工如何處理您的交易。交易數據結構有2個屬性設計"gas": "gasPrice","gasLimit"。
"gasPrice": 單位為Gwei, 為 1/1000個eth,表示交易費用
"gasLimit": 交易允許使用的最大gas費用。
這2個值通常由錢包提供商自動填寫。
除此之外還需要指定在哪個以太坊網路上執行交易(chainId): 1表示以太坊主網。
在開發時,通常會在本地以及測試網路上進行測試,通過測試網路發放的測試ETH進行交易以避免經濟損失。在測試完成後再進入主網交易。
另外,如果需要提交一些其它數據,可以用"data"和"nonce"作為事務的一部分附加。
A nonce(僅使用1次的數字)是以太坊網路用於跟蹤交易的數值,有助於避免網路中的雙重支出以及重放攻擊。
以太坊交易簽名
以太坊交易會涉及ECDSA演算法,以Javascript代碼為例,使用流行的ethers.js來調用ECDSA演算法進行交易簽名。
可以使用在線使用程序Composer將已簽名的交易傳遞到以太坊網路。這種做法被稱為」離線簽名「。離線簽名對於諸如狀態通道之類的應用程序特別有用,這些通道是跟蹤兩個帳戶之間余額的智能合約,並且在提交已簽名的交易後就可以轉移資金。離線簽名也是去中心化交易所(DEXes)中的一種常見做法。
也可以使用在線錢包通過以太坊賬戶創建簽名驗證和廣播。
使用Portis,您可以簽署交易以與加油站網路(GSN)進行交互。
鏈喬教育在線旗下學碩創新區塊鏈技術工作站是中國教育部學校規劃建設發展中心開展的「智慧學習工場2020-學碩創新工作站 」唯一獲準的「區塊鏈技術專業」試點工作站。專業站立足為學生提供多樣化成長路徑,推進專業學位研究生產學研結合培養模式改革,構建應用型、復合型人才培養體系。
2. 「區塊鏈養貓」是個什麼怎麼玩(非常詳盡的教程)
這一次,喵星人又在區塊鏈世界meow了一波高潮。
幾天時間里,"區塊鏈養貓"已經成為幣圈的熱點。
CryptoKitties 加密貓是第一個使用區塊鏈技術,運行在以太坊網路的虛擬寵物游戲。
她的出現具有了某種歷史意義,目前已經成為了以太坊區塊鏈上最受歡迎的項目,一度占據了整個以太坊 20% 的流量。市場的交易額已達幾百萬美元,而且這個數據仍在快速增長著...
這個概念很簡單。你使用以太幣購買一隻貓咪,每個貓咪都是獨一無二的,只要你不賣,它100% 由你所有,不能被復制,不能被銷毀。
好玩之處在於你可以去市場找貓配種,或者在買一隻貓咪,兩兩相配,生出的小貓就屬於你的啦。
而每個小貓都是從父母那裡提取一定序列進行組合,無論從毛色、斑紋、瞳孔、還是發型、表情、尾巴等特徵都是隨機的,總計有40億種變化的可能。然後可以把你的貓咪在市場上賣出,價格你自己定。
還有一點,每隔15分鍾,就會誕生1個gen 0 的創世貓,它的價格相當於最新售賣出去的5隻貓均價的基礎上再增加50%。當然創世貓是受熱捧的,畢竟人家是virgin嘛,生小貓速度是最快的。
這是不是有點像我們雞生蛋,蛋生雞,子子孫孫無窮匱也的故事呢?
當然生孩子是要靠時間的。
一直小貓的誕生從快快快到慢~慢~慢~,差距從一分鍾到一個星期不等。
如果你的貓咪生產的時間越短,越有利。這樣可以把新生的加密貓快速賣出,並繼續繁殖。這也意味著收入的增加。
生的越多,貓咪的cooldowns冷卻時間就越長,生育速度也會降下來。
還有一個好玩的是,生小貓咪是一個復雜的繁育系統和隨機的,意味著總有些變異屬性 (cattributes)出現其中,這些就變成了收藏品或者緊俏品。
1. 進入加密貓官網: cryptokitties.co 點擊sign in 會跳到注冊頁面。需要你在chrome或者firefox瀏覽器上安裝以太坊輕錢包 MetaMask 插件。(這過程是要可學上的, 這里有三種方式 ,怎麼順手怎麼來吧,客官。 密碼:1rjo )
2. 點擊 Mertamask 插件進行安裝。
3. 接受條款,輸入密碼。
4. 生成的12個英文單詞密碼你可要一定一定記住了。連同jason文件一起保存好。
5. 然後錢包創建完成啦。進入 cryptokitties.co 網站就可以看到你的賬戶了,設置姓名郵箱等。
方式一:如果你的其他以太坊錢包里有ETH,比如imtoken,可以直接轉賬到你的加密貓地址即可。
方式二:在這篇文章提到過的 3個場外比特幣交易所比較 的其中兩個: Coincola 和 bitcoinworld 均支持ETH交易,也可以直接上面直接轉過去。
方式三:是Matamask推薦的coinbase,不過顯示 US only.
1. 去marketplace尋找你喜歡的貓咪吧(如下圖)。
2. 看中之後,點擊buy now.
詳情頁顯示了貓的詳細信息,編號,價格趨勢圖(1天或2天隨著時間價格持續增加或減少),現在購買的價格,以及生小貓的冷卻時間等。
3. 點擊 ok,buy this kitty後, matamask會彈出顯示詳細的預計花費。如果出現沒成績,可能你的礦工費給的不夠,或者貓咪賣出,多試試吧。max transaction fee是顯示最大的交易費,一般不會到的。summit後就等待交易完成吧。取消交易,點擊reject.
交易過程中可以點擊該筆交易進入https://etherscan.io查看詳情。或者在網站右側的類似心電圖的圖標查看歷史交易信息。
4. 交易成功!恭喜你,擁有了第一個虛擬貓咪啦。怎麼賺更多呢?
一種方式,生。
兩兩配對。生小貓也是要交交易費的。生的速度要看父母的速度。
Breed kitty 生小貓;
Sell kitty 賣掉小貓
Gift kitty 送小貓給朋友
另一種方式是,出租。
Sire to the public,意思是把你的貓咪當做公貓租出去,設置初始價格和結束價格和日期,充當精子庫吧。
sire to my kitties,意思是讓你的兩個貓XXOO生小貓。
最終的方式是賣。
小貓生出啦,郵件會通知你。可以選擇賣出,設置價格就可以出售啦。
如果有人買走,也會郵件通知你。
好啦,讓我們愉快的做個貓奴吧~
原文: http://li-wu.net/how-to-cryptokitties.html
3. shib提錯到了heco怎麼找回
比特派錢包導出私鑰,導入到火幣錢包的heco鏈,查到shib在heco的合約地址,添加資產裡面填進去就在裡面。
HECOBSCETH的充值地址都是0x開頭,很多朋友著急或者手誤,容易復制錯地址,導致BSC鏈上的代幣被錯轉到了HECO或者ETH鏈上。這種情況怎麼處理呢,往下面看!
首先區分一下被轉錯的鏈和平台,比如你本來要轉BSC鏈上的USDT到交易所,但是不小心地址復製成了交易所ETH鏈的USDT充值地址也就是ERC20的充值地址,這種情況自己沒有辦法去找回幣,需要聯系平台的在線客服,走退迴流程,給你退回到你提現的地址。
如果你是轉到鏈上,你從交易所提BSC鏈上的USDT,地址你不小心寫成了ETH鏈上的地址,你在自己的BSC錢包怎麼都找不到USDT,但是鏈上顯示到賬了,這個時候,這個幣去了哪裡呢?這個幣就在和你ETH地址相同的BSC鏈上錢包里,你只需要把ETH鏈上錢包的助記詞導入BSC鏈上,就能看到USDT,如果看不到,就在錢包里添加一下該鏈上USDT的合約。
下面是轉錯到鏈上操作的實例:
1、3月份這位朋友找到我,說他轉錯了鏈,他要把USDT轉去BSC鏈上,但是從抹茶交易所提幣的時候,走了ERC20的鏈。
2、他的幣怎麼能找到呢,就是把BSC錢包的助記詞導入ETH鏈上錢包。
備注一下:BSC鏈在一些平台的顯示是BEP20;例子已徵求當事人同意;
4. imtoken錢包轉賬失敗怎麼回事
imtoken錢包轉賬失敗怎麼回事,相信很多人在使用imtoken錢包的時候經常的會碰到轉賬失敗的情況,不少人不知道這個情況是怎麼引起的,下面跟著小編一起來看看吧。
imtoken錢包轉賬失敗怎麼回事
Outofgas(Gas不足)
打個通俗易懂的比喻吧,就像你開車必須要有汽油一樣,你在以太坊上轉賬也需要有Gas。開車≈轉賬,汽油≈Gas。如果你要從A地驅車前往B地,按照實時的交通情況,你需要消耗200升汽油。但你為這次行程只准備了150升汽油,那是派攔否能到達B地呢?在現實生活中,大家肯定都知道,你一定是到不了的。同時雖然你沒到達B地,但是你的汽油卻已經消耗了。
那麼回到區塊鏈的世界,也是同樣的道理。如果你要進行一筆轉賬,就要為這筆轉賬設置一個Gas。如果你設置的過低,就會出現「汽車」沒到達目的地就沒「油」的情況,即交易失敗。失敗原因就是outofgas(汽油不足)。同時,又因為礦工們已經進行了打絕羨首包的操作,但在打包過程中發現Gas不足,導致這筆交易打包失敗了。礦工費仍然會被扣除,但這些礦工費都是由礦工們收取的,imToken並不收你一分錢。
BadInstruction(指令錯誤)
Badinstruction字面意思是「指令錯誤」。出現這種提示的原因,大概率是因為智能合約的代碼本身就存在邏輯問題,從而導致合約在執行的過程中,出現「指令錯誤」。這就像一台壞了的機器,你輸入一個指令,機器是不能正常運作的。這時候,我們該找誰解決呢?當然是智能合約的創建方,去修復這台「壞了的機器」。另外轉賬的礦工費仍然會被礦工收走。
Reverted(回退)
以太坊上包含兩類賬戶,普通賬戶和合約賬戶。普通賬戶是由用戶通過私鑰控制,而合約賬戶是由部署在以太坊上的智能合約控制。
那麼,reverted是什麼情況呢?reverted其實是一個函數,用於立即中止合約的執行,並且把狀態回滾。雖然是智能合約,比一般的合約更「聰明」,但是有些合約在執行的過程中還是會「犯錯」的。
這聽起來是不是過於抽象,讓我們打個簡單的比方。出現reverted的一種可能情況:你的合約規定,當你輸入一塊錢,你可以得到一杯喜茶並數。但是這個合約並沒有檢查庫存里是否有足夠的喜茶。當店裡沒有喜茶庫存的時候,後面來的人,即使它輸入一塊錢,也不能得到喜茶。這時候,你原本的函數-即輸入一塊錢就會得到一杯喜茶的函數就會失敗,它會發出錯誤的信息並回滾到當前的交易狀態。
看到這里,想必大家也已經明白了,出現badinstruction和reverted,都是因為智能合約的問題,所以建議大家直接去找合約的創建者,也就是項目方。
5. 以太坊是如何挖礦的
以太坊的代幣是通過采礦過程中產生的,每塊采礦率為 5 個以太幣。以太坊的采礦過程幾乎與比特幣相同,對於每一筆交易,礦工都可以使用計算機通過散列函數運行該塊的唯一標題元數據,反復,快速地猜出答案,直到其中一人獲勝。
許多新用戶認為,采礦的唯一目的是以不需要中央發行人的方式生成醚(參見我們的指南「 什麼是以太? 」)。這是真的。以太坊的代幣是通過采礦過程中產生的,每塊采礦率為 5 個以太幣。但是,采礦還有至少同樣重要的作用。通常,銀行負責保持交易的准確記錄。他們確保資金不是憑空創造的,用戶不會多次欺騙和花錢。不過,區塊鏈引入了一種全新的記錄保存方式,整個網路而不是中介,驗證交易並將其添加到公共分類賬。
Ethereum Mining
盡管「無信任」或「信任最小化」貨幣體系是目標,但仍有人需要確保財務記錄的安全,確保沒有人作弊。采礦是使分散記錄成為可能的創新之一。礦工們在防止欺詐行為(特別是醚的雙重支出)方面達成了關於交易歷史的共識 – 這是一個有趣的問題,在分散化的貨幣未在工作區塊鏈之前解決。雖然以太坊正在研究其他方法來就交易的有效性達成共識,但采礦目前將平台保持在一起。
挖礦如何工作
今天,以太坊的采礦過程幾乎與比特幣相同。對於每一筆交易,礦工都可以使用計算機反復,快速地猜出答案,直到其中一人獲勝。更具體地說,礦工將通過散列函數(它將返回一個固定長度,亂序的數字和字母串,它看起來是隨機的)運行該塊的唯一標題元數據(包括時間戳和軟體版本),只改變』nonce 值』 ,這會影響結果散列值。
如果礦工發現與當前目標相匹配的散列,礦工將被授予乙醚並在整個網路上廣播該塊,以便每個節點驗證並添加到他們自己的分類賬副本中。如果礦工 B 找到散列,礦工 A 將停止對當前塊的工作,並為下一個塊重復該過程。礦工很難在這場比賽中作弊。沒有辦法偽造這項工作,並拿出正確的謎題答案。這就是為什麼解謎方法被稱為「工作證明」。
另一方面,其他人幾乎沒有時間驗證散列值是否正確,這正是每個節點所做的。大約每 12-15 秒,一名礦工發現一塊石塊。如果礦工開始比這更快或更慢地解決謎題,演算法會自動重新調整問題的難度,以便礦工回彈到大約 12 秒鍾的解決時間。
礦工們隨機賺取這些乙醚,他們的盈利能力取決於運氣和他們投入的計算能力。以太坊使用的具體工作量驗證演算法被稱為』ethash』,旨在需要更多的內存,使得使用昂貴的 ASIC 難以開采 – 特殊的采礦晶元,現在是唯一可以盈利的比特幣開采方式。
從某種意義上講,ethash 可能已經成功實現了這一目的,因為專用 ASIC 不可用於以太坊(至少目前還沒有)。此外,由於以太坊旨在從工作證明挖掘轉變為「股權證明」(我們將在下面討論),購買 ASIC 可能不是一個明智的選擇,因為它可能無法長久證明有用。
轉移到股權證明
不過,以太坊可能永遠不需要礦工。開發人員計劃放棄工作證明,即網路當前使用的演算法來確定哪些交易是有效的,並保護其免受篡改,以支持股權證明,網路由代幣所有者擔保。如果並且當該演算法推出時,股權證明可以成為實現分布式共識的一種手段,而該共識使用更少的資源。
6. 以太坊是什麼丨以太坊開發入門指南
以太坊是什麼丨以太坊開發入門指南
很多同學已經躍躍欲試投入到區塊鏈開發隊伍當中來,可是又感覺無從下手,本文將基於以太坊平台,以通俗的方式介紹以太坊開發中涉及的各晦澀的概念,輕松帶大家入門。
以太坊是什麼
以太坊(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來搭建一個測試網路。
註:本文中為了方便大家理解,對一些概念做了類比,有些嚴格來不是准確,不過我也認為對於初學者,也沒有必要把每一個概念掌握的很細致和准確,學習是一個逐步深入的過程,很多時候我們會發現,過一段後,我們會對同一個東西有不一樣的理解。