區塊鏈函數
A. 鍖哄潡閾炬妧鏈4錛氬瘑鐮佸︿箣鍝堝笇
瀵嗙爜瀛︾殑鍔犲瘑瀹堟姢鑰咃細鍝堝笇鍑芥暟鍦ㄥ尯鍧楅摼涓鐨勫姏閲
鍦ㄦ暟瀛楃粡嫻庣殑涓栫晫閲岋紝鍖哄潡閾炬妧鏈鍑鍊熷叾鍘諱腑蹇冨寲鍜屽畨鍏ㄦэ紝姝i犺嗕紶緇熶氦鏄撴柟寮忋傛瘮鐗瑰竵鐨勮癁鐢燂紝灝辨槸瀵嗙爜瀛︽妧鏈鐗瑰埆鏄鍝堝笇鍑芥暟鐨勬澃浣溿傚搱甯屽嚱鏁幫紝榪欎釜鐪嬩技紲炵樼殑綆楁硶錛屽叾瀹炴壆婕旂潃鍏抽敭瑙掕壊錛岀『淇濅簡浜ゆ槗鐨勯忔槑鎬у拰闃叉鴻瘓鑳藉姏銆
鍝堝笇鍑芥暟鐨勯瓟娉曪細紜瀹氭у拰鎶楀啿紿
鍝堝笇鍑芥暟鐨勬牳蹇冪壒鎬у湪浜庡叾鎺ユ敹浠諱綍杈撳叆騫剁敓鎴愬滻瀹氶暱搴﹁緭鍑猴紝濡係HA-256綆楁硶錛屽畠閫氳繃寮傛垨榪愮畻蹇閫熻$畻錛岀敓鎴愮殑64浣16榪涘埗鏁e垪鍊煎叿鏈夋棤娉曡繕鍘熺殑鍗曞悜鎬с傜悊鎯崇殑鍝堝笇鍑芥暟瑕佹眰鍏峰囦簲涓鐗規э細紜瀹氭с佸揩閫熻$畻銆佹姉鍐茬獊銆侀洩宕╂晥搴斿拰闅愯棌銆傛姉鍐茬獊浣垮緱SHA-256閬垮厤浜嗗嚑涔庝笉鍙鑳界殑2^256嬈¤緭鍏ュ啿紿侊紝濡傚湪媯嫻媥code鍚庨棬鏃訛紝閫氳繃MD5鐨勬暎鍒楃『璁よ蔣浠舵潵婧愮殑鐪熷疄鎬с
闅愯棌鐨勫姏閲忎笌puzzle friendliness
鍝堝笇鍑芥暟鐨勯殣鈃忕壒鎬э紝濡侻D5錛岄氳繃娣誨姞闅忔満鎬т繚鎶や俊鎮錛屾瘮濡備笘鐣屾澂棰勬祴緇撴灉錛岃╅勬祴鍊煎彉寰楅毦浠ョ洿鎺ユ帹鏂銆傝宲uzzle friendliness錛屽嵆闅句互蹇閫熸壘鍒版弧瓚崇壒瀹氭潯浠剁殑杈撳叆錛屾f槸姣旂壒甯佸伐浣滈噺璇佹槑錛圥roof of Work錛夎儗鍚庣殑鍏抽敭鏈哄埗錛屽畠紜淇濅簡鍖哄潡閾劇殑瀹夊叏鎬у拰鍘諱腑蹇冨寲銆
SHA-256鐨勮$畻涔嬫棶
SHA-256綆楁硶鐨勮$畻榪囩▼鏋佷負澶嶆潅錛岄氳繃64嬈¤凱浠o紝鍒濆嬪悜閲忓拰杞嬈℃洿鏂拌勫垯錛屼互鍙64涓璐ㄦ暟絝嬫柟鏍圭殑甯擱噺鍙備笌錛岀『淇濅簡姣忎竴姝ョ殑榪愮畻閮芥槸鐙涓鏃犱簩鐨勩傚湪娑堟伅澶勭悊闃舵碉紝鍗充嬌鏄鐭杈撳叆錛屼篃浼氳鎵╁睍騫跺~鍏呰嚦512浣嶇殑鍊嶆暟錛屼互閫傚簲Merkle-Damgard緇撴瀯錛屼負鍖哄潡閾劇殑鍔犲瘑鍜岄獙璇佹彁渚涘熀紜銆
鍖哄潡閾句腑鐨勫搱甯屽簲鐢
鍦ㄥ尯鍧楅摼涓栫晫錛屽搱甯屽嚱鏁扮殑浣滅敤鑷沖叧閲嶈併傚伐浣滈噺璇佹槑鏈哄埗涓錛岀熆宸ラ渶瑙e喅澶嶆潅鐨勫搱甯岃$畻闅鵑橈紝鑰屽尯鍧楀唴瀹圭殑鏍¢獙鍒欎緷璧栦簬鍝堝笇鍊肩殑涓鑷存с傝繖浜涘姛鑳界『淇濅簡浜ゆ槗鐨勪笉鍙綃℃敼鎬э紝鏄鍖哄潡閾懼幓涓蹇冨寲淇′換鍩虹煶鐨勪竴閮ㄥ垎銆傛繁鍏ョ悊瑙e搱甯岋紝灝辨槸鎺屾彙浜嗗尯鍧楅摼鎶鏈鐨勪竴鎶婇掗鍖欙紝濡傘1銆態lock hashing algorithm, 銆2銆戞瘮鐗瑰竵涔︾睄PDF, 銆3銆慡HA-2, 銆4銆慡HA256綆楁硶璇﹁В絳夎祫婧愶紝涓烘帰緔㈣繖涓鍔犲瘑瀹囧畽鎻愪緵浜嗗疂璐電殑鐭ヨ瘑銆
鍖哄潡閾炬妧鏈鐨勫瘑鐮佸︿箣鏃咃紝鍝堝笇鍑芥暟鏃犵枒鏄閭d釜涓嶅彲鎴栫己鐨勫畧鎶よ咃紝瀹冪殑紲炵樹笌鍔涢噺錛屾i┍鍔ㄧ潃鏁板瓧緇忔祹鐨勯潻鏂般
B. 鍦ㄥ尯鍧楅摼涓涓鑸浣跨敤浠涔堝姞瀵嗙畻娉
鍦ㄥ尯鍧楅摼涓錛屼竴鑸浣跨敤涓ょ嶄富瑕佺殑鍔犲瘑綆楁硶錛
- 鍏閽/縐侀掗鍔犲瘑綆楁硶錛氳繖縐嶅康緇濆姞瀵嗙畻娉曚嬌鐢ㄤ竴瀵瑰叕閽ュ拰縐侀掗銆傚叕閽ュ彲浠ュ叕寮鍒嗗彂錛岃岀侀掗闇瑕佷繚瀵嗐傚彧鏈夋嫢鏈夌侀掗鐨勪漢鎵嶈兘瑙e瘑浣跨敤鍏閽ュ姞瀵嗙殑鏁版嵁銆傝繖縐嶅姞瀵嗘柟娉曡騫挎硾鐢ㄤ簬鏁板瓧絳懼悕鍜岃韓浠介獙璇侊紝鍥犱負瀹冨彲浠ョ『璁ゆ暟鎹鐨勬潵婧愬拰瀹屾暣鎬с傚湪鍖哄潡閾句腑錛岀侀掗鐢ㄤ簬紜璁や氦鏄撹呯殑韜浠斤紝鑰屽叕閽ュ垯琚騫挎挱緇欑綉緇滀腑鐨勫叾浠栬妭鐐逛互楠岃瘉浜ゆ槗鐨勬湁鏁堟ф壈楂樼瑧銆
- RSA綆楁硶錛氳繖鏄涓縐嶅父鐢ㄧ殑鍏閽/縐侀掗鍔犲瘑綆楁硶錛岀敱Ron Rivest銆丄di Shamir 鍜 Leonard Adleman浜1978騫村彂鏄庛傚畠鏄涓縐嶉潪瀵圭О鍔犲瘑綆楁硶錛屼篃灝辨槸璇達紝鐢ㄤ簬鍔犲瘑鐨勫瘑閽ュ拰鐢ㄤ簬瑙e瘑鐨勫瘑閽ユ槸涓嶅悓鐨勩
- ECDSA錛堟き鍦嗘洸綰挎暟瀛楃懼悕綆楁硶錛夛細榪欐槸涓縐嶅熀浜嶳SA綆楁硶鐨勬敼榪涚増錛屼嬌鐢ㄦき鍦嗘洸綰垮瘑鐮佸︼紝浣垮緱絳懼悕榪囩▼鏇村揩閫熶笖鏇村畨鍏ㄣ傚湪鍖哄潡閾句腑錛孍CDSA琚鐢ㄤ簬楠岃瘉浜ゆ槗鐨勬暟瀛楃懼悕銆
鎷撳睍鐭ヨ瘑錛
鍝堝笇鍑芥暟鏄涓縐嶅皢浠繪剰闀垮害鐨勬暟鎹錛堝傛枃鏈銆佹暟瀛楃瓑錛夎漿鎹涓哄滻瀹氶暱搴︼紙閫氬父涓256浣嶆垨512浣嶏級鐨勬憳瑕佺殑鏂規硶銆傚畠浠緙撳惈闈炲父蹇涓旈潪甯稿畨鍏錛屽洜涓烘敼鍙樻暟鎹涓鐨勪竴灝忛儴鍒嗭紙鍗充嬌鏄寰灝忕殑鏀瑰彉錛変細瀵艱嚧鍝堝笇緇撴灉鐨勫彉鍖栭潪甯稿ぇ錛岀敋鑷充笉鍙閫嗐傝繖縐嶇壒鎬т嬌寰楀搱甯屽嚱鏁板湪鍖哄潡閾句腑琚騫挎硾浣跨敤錛屽傚尯鍧楃殑merkle鏍戠粨鏋勩佷氦鏄撶殑鏁板瓧絳懼悕浠ュ強瀵嗙爜瀛﹂挶鍖呯殑瀛樺偍絳夈
姣旂壒甯佸尯鍧楅摼涓昏佷嬌鐢⊿HA-256浣滀負鍏跺搱甯屽嚱鏁幫紝榪欐槸鐢盌avid Chaum鍜孧ayra P. Chilomchik鍦1997騫村紩鍏ョ殑涓縐嶇畻娉曘係HA-256鎻愪緵浜嗕竴縐嶉潪甯稿畨鍏ㄧ殑鏂瑰紡鏉ュ壋寤哄尯鍧楅摼騫剁『淇濅氦鏄撶殑瀹夊叏鎬с傛ゅ栵紝鍖哄潡閾句腑鐨凪erkle鏍戠粨鏋勪篃鏄鍩轟簬SHA-256鐨勫搱甯屽嚱鏁版潵鍒涘緩鐨勩
浠ヤ笂涓ょ嶅姞瀵嗙畻娉曞拰鍝堝笇鍑芥暟鍦ㄥ尯鍧楅摼涓閮芥壆婕旂潃闈炲父閲嶈佺殑瑙掕壊錛屽畠浠淇濊瘉浜嗕氦鏄撶殑瀹夊叏鎬с佸畬鏁存у拰鍖垮悕鎬э紝鍚屾椂涔熺『淇濅簡鍖哄潡閾劇綉緇滅殑鍘諱腑蹇冨寲鍜屼笉鍙綃℃敼鎬с
鍚屾椂錛岀敱浜庡尯鍧楅摼涓鐨勬暟鎹鏄浠ュ尯鍧楃殑褰㈠紡涓嶆柇澧為暱鐨勶紝榪欎簺鍔犲瘑綆楁硶榪樿鐢ㄤ簬鍒涘緩鍖哄潡澶村拰鍖哄潡闂寸殑閾炬帴錛岃繘涓姝ユ彁楂樹簡鍖哄潡閾劇殑鎬ц兘鍜屽畨鍏ㄦс
C. 區塊鏈技術
背景:比特幣誕生之後,發現該技術很先進,才發現了區塊鏈技術。比特幣和區塊鏈技術同時被發現。
1.1 比特幣誕生的目的:
①貨幣交易就有記錄,即賬本;
②中心化機構記賬弊端——可篡改;易超發
比特幣解決第一個問題:防篡改——hash函數
1.2 hash函數(加密方式)
①作用:將任意長度的字元串,轉換成固定長度(sha256)的輸出。輸出也被稱為hash值。
②特點:很難找到兩個不同的x和y,使得h(x)=h(y)。
③應用:md5文件加密
1.3 區塊鏈
①定義
區塊:將總賬本拆分成區塊存儲
區塊鏈:在每個區塊上,增加區塊頭。其中記錄父區塊的hash值。通過每個區塊存儲父區塊的hash值,將所有的區塊按照順序連接起來,形成區塊鏈。
②區塊鏈如何防止交易記錄被篡改
形成區塊鏈後,篡改任一交易,會導致該交易區塊hash值和其子區塊中不同,發現篡改。
即使繼續篡改子區塊頭中hash值,會導致子區塊hash值和孫區塊中不同,發現篡改。
1.4 區塊鏈本質
①比特幣和區塊鏈本質:一個人人可見的大賬本,只記錄交易。
②核心技術:通過密碼學hash函數+數據結構,保證賬本記錄不可篡改。
③核心功能:創造信任。法幣依靠政府公信力,比特幣依靠技術。
1.5如何交易
①進行交易,需要有賬號和密碼,對應公鑰和私鑰
私鑰:一串256位的二進制數字,獲取不需要申請,甚至不需要電腦,自己拋硬幣256次就生成了私鑰
地址由私鑰轉化而成。地址不能反推私鑰。
地址即身份,代表了在比特幣世界的ID。
一個地址產生之後,只有進入區塊鏈賬本,才能被大家知道。
②數字簽名技術
簽名函數sign(張三的私鑰,轉賬信息:張三轉10元給李四) = 本次轉賬簽名
驗證韓式verify(張三的地址,轉賬信息:張三轉10元給李四,本次轉賬簽名) = True
張三通過簽名函數sign(),使用自己的私鑰對本次交易進行簽名。
任何人可以通過驗證韓式vertify(),來驗證此次簽名是否有由持有張三私鑰的張三本人發出。是返回true,反之為false。
sign()和verify()由密碼學保證不被破解。·
③完成交易
張三將轉賬信息和簽名在全網供內部。在賬戶有餘額的前提下,驗證簽名是true後,即會記錄到區塊鏈賬本中。一旦記錄,張三的賬戶減少10元,李四增加10元。
支持一對一,一對多,多對已,多對多的交易方式。
比特幣世界中,私鑰就是一切!!!
1.6中心化記賬
①中心化記賬優點:
a.不管哪個中心記賬,都不用太擔心
b.中心化記賬,效率高
②中心化記賬缺點:
a 拒絕服務攻擊
b 厭倦後停止服務
c 中心機構易被攻擊。比如破壞伺服器、網路,監守自盜、法律終止、政府幹預等
歷史 上所有有中心化機構的機密貨幣嘗試都失敗了。
比特幣解決第二個問題:如何去中心化
1.7 去中心化記賬
①去中心化:人人都可以記賬。每個人都可以保留完整的賬本。
任何人都可以下載開源程序,參與P2P網路,監聽全世界發送的交易,成為記賬節點,參與記賬。
②去中心化記賬流程
某人發起一筆交易後,向全網廣播。
每個記賬節點,持續監聽、持續全網交易。收到一筆新交易,驗證准確性後,將其放入交易池並繼續向其它節點傳播。
因為網路傳播,同一時間不同記賬節點的交一次不一定相同。
每隔10分鍾,從所有記賬節點當中,按照某種方式抽取1名,將其交易池作為下一個區塊,並向全網廣播。
其它節點根據最新的區塊中的交易,刪除自己交易池中已經被記錄的交易,繼續記賬,等待下一次被選中。
③去中心化記賬特點
每隔10分鍾產生一個區塊,但不是所有在這10分鍾之內的交易都能記錄。
獲得記賬權的記賬節點,將得到50個比特幣的獎勵。每21萬個區塊(約4年)後,獎勵減半。總量約2100萬枚,預計2040年開采完。
記錄一個區塊的獎勵,也是比特幣唯一的發行方式。
④如何分配記賬權:POW(proof of work) 方式
記賬幾點通過計算一下數學題,來爭奪記賬權。
找到某隨即數,使得一下不等式成立:
除了從0開始遍歷隨機數碰運氣之外,沒有其它解法,解題的過程,又叫做挖礦。
誰先解對,誰就得到記賬權。
某記賬節點率先找到解,即向全網公布。其他節點驗證無誤之後,在新區塊之後重新開始新一輪的計算。這個方式被稱為POW。
⑤難度調整
每個區塊產生的時間並不是正好10分鍾
隨著比特幣發展,全網算力不算提升。
為了應對算力的變化,每隔2016個區塊(大約2周),會加大或者減少難度,使得每個區塊產生的平均時間是10分鍾。
#歐易OKEx# #比特幣[超話]# #數字貨幣#
D. 區塊鏈技術中的哈希演算法是什麼
1.1. 簡介
計算機行業從業者對哈希這個詞應該非常熟悉,哈希能夠實現數據從一個維度向另一個維度的映射,通常使用哈希函數實現這種映射。通常業界使用y = hash(x)的方式進行表示,該哈希函數實現對x進行運算計算出一個哈希值y。
區塊鏈中哈希函數特性:
函數參數為string類型;
固定大小輸出;
計算高效;
collision-free 即沖突概率小:x != y => hash(x) != hash(y)
隱藏原始信息:例如區塊鏈中各個節點之間對交易的驗證只需要驗證交易的信息熵,而不需要對原始信息進行比對,節點間不需要傳輸交易的原始數據只傳輸交易的哈希即可,常見演算法有SHA系列和MD5等演算法
1.2. 哈希的用法
哈希在區塊鏈中用處廣泛,其一我們稱之為哈希指針(Hash Pointer)
哈希指針是指該變數的值是通過實際數據計算出來的且指向實際的數據所在位置,即其既可以表示實際數據內容又可以表示實際數據的存儲位置。下圖為Hash Pointer的示意圖
![](http://www.yuanxue365.com/images/loading.jpg)