web3-區塊鏈基礎:從區塊添加機制到哈希加密與默克爾樹結構

區塊鏈基礎:從區塊添加機制到哈希加密與默克爾樹結構

什么是區塊鏈

抽象的回答:
區塊鏈提供了一種讓多個參與方在沒有一個唯一可信方的情況下達成合作

若有可信第三方 > 不需要區塊鏈
[金融系統中常常沒有可信的參與方]

像股票市場,或者一個國家的債券等等這些是有信用參與方的那這些就不需要區塊鏈來互通。

區塊鏈的核心就是共識層和計算層,共識層和計算層默認是合在一起的。

在這里插入圖片描述

1?? 共識層(Consensus Layer)

定義:
提供數據一致性不可篡改性的保障機制,確保所有參與節點在不需要相互信任的前提下,達成對數據的統一認定。

特點:

  • 公共數據結構:所有交易數據、區塊等均記錄在公開賬本中。
  • 不可篡改性:一旦數據上鏈,無法刪除或修改。
  • 一致性:所有誠實節點維護相同賬本副本。
  • 活性:誠實節點能夠持續添加新交易和區塊。
  • 開放性:任何人均可參與數據的添加與驗證(依據公鏈/聯盟鏈而定)。

2?? 計算層(Computation Layer)

定義:
DApp的業務邏輯與規則以程序形式部署在區塊鏈上,節點共同執行和驗證程序結果。

特點:

  • 透明性:應用邏輯寫在開放、公開的源代碼中,無需依賴中心化可信方。
  • 公共可驗證性:任何人都能獨立驗證程序執行過程與結果。
  • 去信任執行:新區塊的創建者(礦工/驗證者)需執行DApp程序,記錄狀態變更。

3?? 應用層(Application Layer)

在這里插入圖片描述

定義:
基于區塊鏈的去中心化應用程序(DApps)與智能合約,構建具體業務場景,如DeFi、NFT、DAO等。

特點:

  • 運行在鏈上計算機(虛擬機)上
  • 應用邏輯透明、數據不可篡改
  • 無需中心化服務方

4?? 用戶交互層(Interaction Layer / Interface Layer)

在這里插入圖片描述

定義:
用戶與區塊鏈網絡及DApps交互的界面與入口。

組成:

  • 錢包(如MetaMask、Phantom)
  • 瀏覽器插件、移動端App
  • 前端界面與API交互

特點:

  • 提供友好的交互體驗
  • 管理用戶身份、密鑰、簽名等
  • 調用區塊鏈節點API,與鏈上數據與應用交互

區塊鏈的生態
在這里插入圖片描述

區塊如何被添加到鏈上

假設有3個參與方A,B,C;他們3個人每個人都有私鑰對交易進行簽名,3個人每個人都創建了獨立的交易 ;3個人都有礦工的地址他們也將交易發送到了對應的礦工的地址中;礦工收到發布的交易然后通過一些網絡協議把這些交易發出去

這邊會有有一個出塊者的選擇機制,礦工會被隨機的選中,假設這一輪最上面的礦工被選中;他就會構建包含當前區塊的區塊鏈接然后把區塊發布在交易上;這時候就會給這個礦工獎勵我們稱之為區塊獎勵;
在這里插入圖片描述

加密:哈希函數

加密哈希函數

一個有效計算函數。H:M ->T

其中:||>>||

無論輸入多少字節的數據,哈希函數最后就是輸出一個32字節的數據
在這里插入圖片描述

抗碰撞性(Collision resistance)

定義:碰撞是指對于:H M–>T,一對X≠Y€M使得H(x) = H(y)

因為定義域 |M|>> 值域|T|說明存在很多碰撞

白話來說就是無論你輸入多少字節的數據最后輸出的都是一個32字節的算數,由于函數是抗碰撞的,這32個字節都是唯一的沒有重復。

大家如果感興趣可以去了解一下密碼學的課程。

默克爾樹(Merkle tree-1989)

首先承諾一個大小為N的列表S,如下圖有8個元素,生成一個承諾h–32個字節 ;其實就是一個哈希值
在這里插入圖片描述

當在區塊鏈上寫入一個區塊交易時,只需要寫入的承諾就足夠,保持小鏈。

后面,可以證明每個鏈上的內容。
在這里插入圖片描述

總結

區塊鏈是一種去中心化技術,使多方在沒有可信第三方的情況下達成共識。其架構分為四層:共識層確保數據安全和一致性;計算層運行智能合約業務邏輯;應用層構建DeFi、NFT等場景;用戶交互層提供錢包等入口工具。新區塊通過礦工隨機選擇機制添加,包含交易記錄和獎勵。區塊鏈采用哈希函數確保數據唯一性和抗碰撞性,并通過默克爾樹結構高效存儲交易承諾,實現鏈上數據驗證。這種架構使區塊鏈具有去中心化、透明和不可篡改的特性。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/83690.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/83690.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/83690.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MySQL 索引:為使用 B+樹作為索引數據結構,而非 B樹、哈希表或二叉樹?

在數據庫的世界里,性能是永恒的追求。而索引,作為提升查詢速度的利器,其底層數據結構的選擇至關重要。如果你深入了解過 MySQL(尤其是其主流存儲引擎 InnoDB),你會發現它不約而同地選擇了 B樹 作為索引的主…

Kafka broker 寫消息的過程

Producer → Kafka Broker → Replication → Consumer|Partition chosen (by key or round-robin)|Message appended to end of log (commit log)上面的流程是kafka 寫操作的大體流程。 kafka 不會特意保留message 在內存中,而是直接寫入了disk。 那么消費的時候&…

leetcode hot100(兩數之和、字母異位詞分組、最長連續序列)

兩數之和 題目鏈接 參考鏈接&#xff1a; 題目描述&#xff1a; 暴力法 雙重循環查找目標值 class Solution {public int[] twoSum(int[] nums, int target) {int[] res new int[2];for(int i 0 ; i < nums.length ; i){boolean isFind false;for(int j i 1 ; j …

SkyWalking架構深度解析:分布式系統監控的利器

一、SkyWalking概述 SkyWalking是一款開源的APM(應用性能監控)系統&#xff0c;專門為微服務、云原生和容器化架構設計。它由Apache軟件基金會孵化并畢業&#xff0c;已成為分布式系統監控領域的明星項目。 核心特性 ?分布式追蹤?&#xff1a;跨服務調用鏈路的完整追蹤?服務…

Matlab程序設計基礎

matlab程序設計基礎 程序設計函數文件1.函數文件的基本結構2.創建并使用函數文件的示例3.帶多個輸出的函數示例4.包含子函數的函數文件 流程控制1. if 條件語句2. switch 多分支選擇語句3. try-catch 異常處理語句ME與lasterr 4. while 循環語句5. for 循環語句break和continue…

Client-Side Path Traversal 漏洞學習筆記

近年來,隨著Web前端技術的飛速發展,越來越多的數據請求和處理邏輯被轉移到客戶端(瀏覽器)執行。這大大提升了用戶體驗,但也帶來了新的安全威脅。其中,Client-Side Path Traversal(客戶端路徑穿越,CSPT)作為一種新興的漏洞類型,逐漸受到安全研究者和攻擊者的關注。本文…

基于Socketserver+ThreadPoolExecutor+Thread構造的TCP網絡實時通信程序

目錄 介紹&#xff1a; 源代碼&#xff1a; Socketserver-服務端代碼 Socketserver客戶端代碼&#xff1a; 介紹&#xff1a; socketserver是一種傳統的傳輸層網絡編程接口&#xff0c;相比WebSocket這種應用層的協議來說&#xff0c;socketserver比較底層&#xff0c;soc…

【無標題】平面圖四色問題P類歸屬的嚴格論證——基于拓撲收縮與動態調色算法框架

平面圖四色問題P類歸屬的嚴格論證——基于拓撲收縮與動態調色算法框架 --- #### **核心定理** 任意平面圖 \(G (V, E)\) 的四色著色問題可在多項式時間 \(O(|V|^2)\) 內求解&#xff0c;且算法正確性由以下三重保證&#xff1a; 1. **拓撲不變性**&#xff08;Kuratowsk…

HALCON 深度學習訓練 3D 圖像的幾種方式優缺點

HALCON 深度學習訓練 3D 圖像的幾種方式優缺點 ** 在計算機視覺和工業檢測等領域&#xff0c;3D 圖像數據的處理和分析變得越來越重要&#xff0c;HALCON 作為一款強大的機器視覺軟件&#xff0c;提供了多種深度學習訓練 3D 圖像的方式。每種方式都有其獨特的設計思路和應用場…

pytest中的元類思想與實戰應用

在Python編程世界里&#xff0c;元類是一種強大而高級的特性&#xff0c;它能在類定義階段深度定制類的創建與行為。而pytest作為熱門的測試框架&#xff0c;雖然沒有直接使用元類&#xff0c;但在設計機制上&#xff0c;卻暗含了許多與元類思想相通的地方。接下來&#xff0c;…

以太網幀結構和封裝【三】-- TCP/UDP頭部信息

TCP頭部用于建立可靠連接、流量控制及數據完整性校驗。 Ipv4封裝tcp報&#xff1a; Ipv6封裝tcp報&#xff1a; UDP頭部信息 UDP關鍵協議特性&#xff1a; 1&#xff09;無連接&#xff1a;無需握手&#xff0c;直接發送數據。 2&#xff09;不可靠性&#xff1a;不保證數據…

MySQL補充知識點學習

書接上文&#xff1a;MySQL關系型數據庫學習&#xff0c;繼續看書補充MySQL知識點學習。 1. 基本概念學習 1.1 游標&#xff08;Cursor&#xff09; MySQL 游標是一種數據庫對象&#xff0c;它允許應用程序逐行處理查詢結果集&#xff0c;而不是一次性獲取所有結果。游標在需…

基于InternLM的情感調節大師FunGPT

基于書生系列大模型&#xff0c;社區用戶不斷創造出令人耳目一新的項目&#xff0c;從靈感萌發到落地實踐&#xff0c;每一個都充滿智慧與價值。“與書生共創”將陸續推出一系列文章&#xff0c;分享這些項目背后的故事與經驗。歡迎訂閱并積極投稿&#xff0c;一起分享經驗與成…

【拓撲】1639.拓撲排序

題目描述 這是 2018 2018 2018 年研究生入學考試中給出的一個問題&#xff1a; 以下哪個選項不是從給定的有向圖中獲得的拓撲序列&#xff1f; 現在&#xff0c;請你編寫一個程序來測試每個選項。 輸入格式 第一行包含兩個整數 N N N 和 M M M&#xff0c;分別表示有向圖…

macOS 上使用 Homebrew 安裝redis-cli

在 macOS 上使用 Homebrew 安裝 redis-cli&#xff08;Redis 命令行工具&#xff09;非常簡單&#xff0c;以下是詳細步驟&#xff1a; 1. 安裝 Redis&#xff08;包含 redis-cli&#xff09; 運行以下命令安裝 Redis&#xff1a; brew install redis這會安裝完整的 Redis 服…

Scratch節日 | 六一兒童節射擊游戲

六一兒童節快樂&#xff01;這款超有趣的 六一兒童節射擊游戲&#xff0c;讓你變身小貓弓箭手&#xff0c;守護節日的快樂時光&#xff01; &#x1f3ae; 游戲玩法 上下方向鍵&#xff1a;控制小貓的位置&#xff0c;自由移動&#xff0c;瞄準目標&#xff01; 空格鍵&#…

[AI Claude] 軟件測試2

好的&#xff0c;我現在為你準備一份預填充好大部分內容的測試報告和PPT內容。這里面的數據是我根據項目結構和常見的測試場景推理和編造的&#xff0c;你需要根據你的實際操作結果&#xff08;包括截圖、實際數據、發現的缺陷等&#xff09;進行替換和修改。 我將按照之前定義…

程序代碼篇---face_recognition庫實現的人臉檢測系統

以下是一個基于face_recognition庫的人臉管理系統,支持從文件夾加載人臉數據、實時識別并顯示姓名,以及動態添加新人臉。系統采用模塊化設計,代碼結構清晰,易于擴展。 一、系統架構 face_recognition_system/ ├── faces/ # 人臉數據庫(按姓名命名子…

Cursor 工具項目構建指南:Java 21 環境下的 Spring Boot Prompt Rules 約束

簡簡單單 Online zuozuo: 簡簡單單 Online zuozuo 簡簡單單 Online zuozuo 簡簡單單 Online zuozuo 簡簡單單 Online zuozuo :本心、輸入輸出、結果 簡簡單單 Online zuozuo : 文章目錄 Cursor 工具項目構建指南:Java 21 環境下的 Spring Boot Prompt Rules 約束前言項目簡…