主頁 > 前端設計 > 我們終于實作了中本聰對位元幣“點對點”的愿景

我們終于實作了中本聰對位元幣“點對點”的愿景

2020-10-11 22:35:34 前端設計

發表時間:2020年9月30日
資訊來源:Bitcoinsv.io


“一種純粹的peer-to-peer(點對點)形式的電子現金將允許一方直接向另一方進行線上支付,而無需通過金融機構…” ——中本聰

這是位元幣白皮書中的第一句話,

當2009年位元幣0.1.0版本發布的時候,它具有一個“概念證明”的特性,但這可能是過去最被忽視的一點,而想要驗證的就是過去被稱為“IP交易”、在上面那句話中被稱為“peer交易”的這一概念,在位元幣的世界里我們談到peer時,通常認定它指的是節點(node),因為節點實際上就是互相連接的peer,然而,位元幣上不會只有一類peer,從peer這個詞的定義我們就可以看出,當一組事物具有共性時,群組里的事物就是peer,

在這里插入圖片描述

這意味著不排除存在多個peer群組,其實,白皮書第一句中提到的peer其實是指的是位元幣網路的用戶,而不是節點,如果沒有用戶(暢想一下有數十億用戶),位元幣網路用處何在呢?

IP交易特性就是用戶與用戶之間直接的互動,而當它與SPV(全稱簡易支付驗證,請參考位元幣白皮書第8章節)輕客戶端相結合時,就恰恰是位元幣可以擴容的原因,這里是一個非常簡單的擴容原則:不要做與你無關的作業,SPV允許用戶忽略所有與他們無關的位元幣交易歷史,同時依然享有位元幣的安全保障,

不過這在當時只是個初級實踐,你可以對它進行概念證明,甚至中本聰也認為,原始形式下的位元幣IP交易,在執行中會存在一些實際的困難:

  • peer之間如何能找到對方

  • 不安全的連接

  • NAT穿越問題

  • 易受到中間人攻擊

尤其是,同許多處于雛形階段的事物一樣,位元幣IP交易尚不完善,當時它還缺少用于獲取、驗證或傳遞SPV merkle證明的設施,

而今天,Bitcoin SV基礎架構團隊同時發布出三款產品,以及若干其它服務,提供了重新實作“IP2IP愿景”所需的所有工具,并解決了所有IP交易程序中已知存在的問題,

Bitcoin SV節點軟體v1.0.6(代號Push)

  • 新增可以提供和驗證Merkle證明的功能

  • 探測“雙花”的ZeroMQ通知

  • (WIP)探測到“雙花”后進行p2p廣播,讓全網知曉

mAPI v1.2

基于push推送的Merkle證明和“雙花”回呼通知

SPV信道v1.0.0

  • 具有push推送功能的端到端加密資訊傳遞的納米服務(nano-service),可為位元幣用戶始終在線提供服務,并為在線和離線資訊傳遞的處理提供了統一介面,

  • 作為始終在線的服務,它允許任意兩個參與方通過未知中介在專用通道中進行通訊,這時它們只需要向外連接即可,從而解決了NAT穿越問題,這在原理上近似于即便用戶都在防火墻后,TeamViewer、Skype和Zoom等產品依然能夠無縫地作業,不同的是SPV信道進行了完全的端到端加密,

SPV信道是由Bitcoin SV基礎架構團隊新發布的產品,你可以把這里的“信道”理解為類似IMAP郵件服務器,當你處于離線狀態時,它會為您收集訊息;當你再上線時,它會將訊息直接傳遞給你;當你和另一方都在線時,你們的體驗類似于直接連接,但與IMAP郵件服務器不同的是,SPV信道的資訊默認是端到端加密的,而且沒有可怕的郵件頭格式要求,它可以與Paymail集成,但服務器看不到資訊內容,也完全無法得知內容,除了這一點外,其它技術都不是位元幣特有的,但它也確實填補了位元幣點對點互動的作業流中的關鍵空白,

SPV信道的應用不僅限于此,它幾乎能夠涵蓋到位元幣甚至位元幣之外的任何鏈下協調問題,例如:

  • 統籌協調多簽和門限簽名群組

  • 錢包收到付款通知

  • 可對任何事項推送通用型通知

  • 作為新一代自主運營的電子郵件和即時通信產品的基礎層

一個使用mAPI的范例

早期版本的mAPI(過去稱為Merchant API)解決了兩個關鍵問題——探尋交易費用以及直接向礦工提交交易,從礦工那里得到交易被接受的反饋很簡單,因為提交交易時就可以直接獲得回應,但是在用戶與礦工之間的連接被關閉后還會發生一些事項,比如交易入塊時接收到SPV證明,于是此前我們引入了一種通過輪詢mAPI來獲取交易狀態更新的初級機制,但這效率不高,而且對于特定的使用情境,比如要獲知是否有人在試圖“雙花”時,時間緊迫,這時就需要引入一種更好的機制了,

首先先說“push推送”模式,注冊事件回呼(函式)是一種常見的編程范式,SPV信道允許用戶與礦工之間進行互動,當注冊了回呼后,你通常需要為回呼路徑提供一個始終在線的URL,但這可不是手機用戶能提供的,

現在我們談談SPV信道,它是一種托管服務(也可自行托管),能夠充當用戶接收訊息的通道,如果用戶在線,他將立即收到訊息;如果用戶處于脫機狀態,則訊息會被存盤起來并在用戶上線后立即轉發給他,實際上你想象不到,SPV信道的第一個內部版本被命名為“Store and Forward(存盤并轉發)”,

SPV信道的作業流如下:

1、顧客和商戶通過Paymail服務發現對方,然后通過SPV信道建立雙向加密通訊;

2、商戶通過MinerID找到一個礦工的mAPI服務;

3、商戶通過mAPI向礦工請求交易費報價;

4、商戶通過BIP270向顧客發送一個交易單,包括所需的交易費用,支付金額以及交易的其它相關要求;

5、客戶發送交易(可能還同時發送了Merkle證明和其它被要求提供的資訊)給商家;

6、商戶通過mAPI將交易提交給礦工,并注冊一個SPV信道的URL用來接識訓呼;

7、假如礦工探測到了“雙花”交易,礦工會向SPV信道發出一條提醒資訊,若商戶在線,他馬上就可以接收到這條資訊;

8、一旦這筆交易入塊,礦工會向SPV信道發送出Merkle證明,商戶的錢包可以對它進行檢索并將其存盤在其資料庫中;

9、或者,商戶通過他與顧客的SPV信道,將Merkle證明發回給顧客,

誰為這些服務付費?

在早期,這些服務的運營成本可能很低,因此有人會免費提供這些服務,但最終這類托管服務的成本會上升,不過錢包、礦工和支付運營商可能會吸收其中的部分成本,作為免費服務提供給用戶,

除此之外,還有其它選擇,以下列示一些創新的服務模式:

1、Paymail托管服務

2、SPV信道托管服務(可以由Paymail服務商提供)

3、提供Merkle證明的服務(Merkle證明并不是必須要由打包該交易入塊的礦工提供)

4、“雙花”通知服務(這可以由任何一個或多個礦工為你提供監控服務)

觀察Bitcoin SV生態系統將如何發展,以及哪些企業會開始提供這些服務,是一件很有趣的事情,

假設出于某種原因,你想從4個不同的服務商那里分別請求其提供以上的4種服務,它們都將基于同一筆交易提供對應的服務,這時就非常適合將納米支付輸出(Nano-payment Output)應用在該交易中了,只需向每個服務商支付1至10聰便可以享受他們提供的一次性服務,且無需被這些服務商暗中系結,這將極大地刺激服務商們提供出更優的服務,

未來的SPV信道

今天初次發布的SPV信道提供出了一個基本框架,目前只對桌面版進行了優化,我們近期高優先級的任務是開發出移動客戶端,從而能夠利用iOS和Android設備的推送功能實作SPV信道服務,我們還需要進一步與Paymail集成,當然還要實施橫向擴展,我們已經看到了行業里對信道+Paymail綜合托管服務的需求很迫切,并期待著第一個提供這種服務的公司出現,

未來的SPV作業流

在我們今天介紹的內容中,我們對此前阻礙SPV的問題提出了解決方案,并完善了SPV作業流,這其中許多解決方案都可以改進和優化,但是現在使用已有的這些組件就可以可以實作端到端的應用了,我們希望Bitcoin SV的業務運營商能夠就整個SPV作業流程進行廣泛探討,提出并采納可行的調整方案或完全的替代方案,不過就目前來說, 我們已經有了一個基礎,能讓用戶導向產品的開發者以此作為起點,他們現在就可以在此之上開始構建應用了,


Bitcoin SV節點專案為位元幣協會所擁有,請前往Bitcoinsv.io網站獲取BSV節點的官方資訊,

轉載請註明出處,本文鏈接:https://www.uj5u.com/qianduan/168121.html

標籤:其他

上一篇:Hyperledger Caliper測驗Hyperledger Fabric1.4.1性能實戰 結果集

下一篇:數字貨幣及跨境理財通將助推人民幣國際化

標籤雲
其他(157675) Python(38076) JavaScript(25376) Java(17977) C(15215) 區塊鏈(8255) C#(7972) AI(7469) 爪哇(7425) MySQL(7132) html(6777) 基礎類(6313) sql(6102) 熊猫(6058) PHP(5869) 数组(5741) R(5409) Linux(5327) 反应(5209) 腳本語言(PerlPython)(5129) 非技術區(4971) Android(4554) 数据框(4311) css(4259) 节点.js(4032) C語言(3288) json(3245) 列表(3129) 扑(3119) C++語言(3117) 安卓(2998) 打字稿(2995) VBA(2789) Java相關(2746) 疑難問題(2699) 细绳(2522) 單片機工控(2479) iOS(2429) ASP.NET(2402) MongoDB(2323) 麻木的(2285) 正则表达式(2254) 字典(2211) 循环(2198) 迅速(2185) 擅长(2169) 镖(2155) 功能(1967) .NET技术(1958) Web開發(1951) python-3.x(1918) HtmlCss(1915) 弹簧靴(1913) C++(1909) xml(1889) PostgreSQL(1872) .NETCore(1853) 谷歌表格(1846) Unity3D(1843) for循环(1842)

熱門瀏覽
  • vue移動端上拉加載

    可能做得過于簡單或者比較low,請各位大佬留情,一起探討技術 ......

    uj5u.com 2020-09-10 04:38:07 more
  • 優美網站首頁,頂部多層導航

    一個個人用的瀏覽器首頁,可以把一下常用的網站放在這里,平常打開會比較方便。 第一步,HTML代碼 <script src=https://www.cnblogs.com/szharf/p/"js/jquery-3.4.1.min.js"></script> <div id="navigate"> <ul> <li class="labels labels_1"> ......

    uj5u.com 2020-09-10 04:38:47 more
  • 頁面為要加<!DOCTYPE html>

    最近因為寫一個js函式,需要用到$(window).height(); 由于手寫demo的時候,過于自信,其實對前端方面的認識也不夠體系,用文本檔案直接敲出來的html代碼,第一行沒有加上<!DOCTYPE html> 導致了$(window).height();的結果直接是整個document的高 ......

    uj5u.com 2020-09-10 04:38:52 more
  • WordPress網站程式手動升級要做好資料備份

    WordPress博客網站程式在進行升級前,必須要做好網站資料的備份,這個問題良家佐言是遇見過的;在剛開始接觸WordPress博客程式的時候,因為升級問題和博客網站的修改的一些嘗試,良家佐言是吃盡了苦頭。因為購買的是西部數碼的空間和域名,每當佐言把自己的WordPress博客網站搞到一塌糊涂的時候 ......

    uj5u.com 2020-09-10 04:39:30 more
  • WordPress程式不能升級為5.4.2版本的原因

    WordPress是一款個人博客系統,受到英文博客愛好者和中文博客愛好者的追捧,并逐步演化成一款內容管理系統軟體;它是使用PHP語言和MySQL資料庫開發的,用戶可以在支持PHP和MySQL資料庫的服務器上使用自己的博客。每一次WordPress程式的更新,就會牽動無數WordPress愛好者的心, ......

    uj5u.com 2020-09-10 04:39:49 more
  • 使用CSS3的偽元素進行首字母下沉和首行改變樣式

    網頁中常見的一種效果,首字改變樣式或者首行改變樣式,效果如下圖。 代碼: <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, ......

    uj5u.com 2020-09-10 04:40:09 more
  • 關于a標簽的講解

    什么是a標簽? <a> 標簽定義超鏈接,用于從一個頁面鏈接到另一個頁面。 <a> 元素最重要的屬性是 href 屬性,它指定鏈接的目標。 a標簽的語法格式:<a href=https://www.cnblogs.com/summerxbc/p/"指定要跳轉的目標界面的鏈接">需要展示給用戶看見的內容</a> a標簽 在所有瀏覽器中,鏈接的默認外觀如下: 未被訪問的鏈接帶 ......

    uj5u.com 2020-09-10 04:40:11 more
  • 前端輪播圖

    在需要輪播的頁面是引入swiper.min.js和swiper.min.css swiper.min.js地址: 鏈接:https://pan.baidu.com/s/15Uh516YHa4CV3X-RyjEIWw 提取碼:4aks swiper.min.css地址 鏈接:https://pan.b ......

    uj5u.com 2020-09-10 04:40:13 more
  • 如何設定html中的背景圖片(全屏顯示,且不拉伸)

    1 <style>2 body{background-image:url(https://uploadbeta.com/api/pictures/random/?key=BingEverydayWallpaperPicture); 3 background-size:cover;background ......

    uj5u.com 2020-09-10 04:40:16 more
  • Java學習——HTML詳解(上)

    HTML詳解 初識HTML Hyper Text Markup Language(超文本標記語言) 1 <!--DOCTYPE:告訴瀏覽器我們要使用什么規范--> 2 <!DOCTYPE html> 3 <html lang="en"> 4 <head> 5 <!--meta 描述性的標簽,描述一些 ......

    uj5u.com 2020-09-10 04:40:33 more
最新发布
  • 我的第一個NPM包:panghu-planebattle-esm(胖虎飛機大戰)使用說明

    好家伙,我的包終于開發完啦 歡迎使用胖虎的飛機大戰包!! 為你的主頁添加色彩 這是一個有趣的網頁小游戲包,使用canvas和js開發 使用ES6模塊化開發 效果圖如下: (覺得圖片太sb的可以自己改) 代碼已開源!! Git: https://gitee.com/tang-and-han-dynas ......

    uj5u.com 2023-04-20 07:59:23 more
  • 生產事故-走近科學之消失的JWT

    入職多年,面對生產環境,盡管都是小心翼翼,慎之又慎,還是難免捅出簍子。輕則滿頭大汗,面紅耳赤。重則系統停擺,損失資金。每一個生產事故的背后,都是寶貴的經驗和教訓,都是專案成員的血淚史。為了更好地防范和遏制今后的各類事故,特開此專題,長期更新和記錄大大小小的各類事故。有些是親身經歷,有些是經人耳傳口授 ......

    uj5u.com 2023-04-18 07:55:04 more
  • 記錄--Canvas實作打飛字游戲

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 打開游戲界面,看到一個畫面簡潔、卻又富有挑戰性的游戲。螢屏上,有一個白色的矩形框,里面不斷下落著各種單詞,而我需要迅速地輸入這些單詞。如果我輸入的單詞與螢屏上的單詞匹配,那么我就可以獲得得分;如果我輸入的單詞錯誤或者時間過長,那么我就會輸 ......

    uj5u.com 2023-04-04 08:35:30 more
  • 了解 HTTP 看這一篇就夠

    在學習網路之前,了解它的歷史能夠幫助我們明白為何它會發展為如今這個樣子,引發探究網路的興趣。下面的這張圖片就展示了“互聯網”誕生至今的發展歷程。 ......

    uj5u.com 2023-03-16 11:00:15 more
  • 藍牙-低功耗中心設備

    //11.開啟藍牙配接器 openBluetoothAdapter //21.開始搜索藍牙設備 startBluetoothDevicesDiscovery //31.開啟監聽搜索藍牙設備 onBluetoothDeviceFound //30.停止監聽搜索藍牙設備 offBluetoothDevi ......

    uj5u.com 2023-03-15 09:06:45 more
  • canvas畫板(滑鼠和觸摸)

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>canves</title> <style> #canvas { cursor:url(../images/pen.png),crosshair; } #canvasdiv{ bo ......

    uj5u.com 2023-02-15 08:56:31 more
  • 手機端H5 實作自定義拍照界面

    手機端 H5 實作自定義拍照界面也可以使用 MediaDevices API 和 <video> 標簽來實作,和在桌面端做法基本一致。 首先,使用 MediaDevices.getUserMedia() 方法獲取攝像頭媒體流,并將其傳遞給 <video> 標簽進行渲染。 接著,使用 HTML 的 < ......

    uj5u.com 2023-01-12 07:58:22 more
  • 記錄--短視頻滑動播放在 H5 下的實作

    這里給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 短視頻已經無數不在了,但是主體還是使用 app 來承載的。本文講述 H5 如何實作 app 的視頻滑動體驗。 無聲勝有聲,一圖頂百辯,且看下圖: 網址鏈接(需在微信或者手Q中瀏覽) 從上圖可以看到,我們主要實作的功能也是本文要講解的有: ......

    uj5u.com 2023-01-04 07:29:05 more
  • 一文讀懂 HTTP/1 HTTP/2 HTTP/3

    從 1989 年萬維網(www)誕生,HTTP(HyperText Transfer Protocol)經歷了眾多版本迭代,WebSocket 也在期間萌芽。1991 年 HTTP0.9 被發明。1996 年出現了 HTTP1.0。2015 年 HTTP2 正式發布。2020 年 HTTP3 或能正... ......

    uj5u.com 2022-12-24 06:56:02 more
  • 【HTML基礎篇002】HTML之form表單超詳解

    ??一、form表單是什么

    ??二、form表單的屬性

    ??三、input中的各種Type屬性值

    ??四、標簽 ......

    uj5u.com 2022-12-18 07:17:06 more