如何使用PHP開發比特幣詳解

什麼是比特幣

當我們談到比特幣時,其實在不同的場景下有不同的指代。

比特幣首先是一種數字加密貨幣,用戶可以通過比特幣網絡進行 比特幣轉賬或商品結算,就和傳統的貨幣一樣:

如何使用PHP開發比特幣詳解

不過比特幣是基於密碼學技術的虛擬化貨幣,它沒有實體,僅僅 隱含在從發送方到接收方的交易中,接收方必須使用其持有的密鑰來 消費收到的比特幣。

對於科技從業者而言,比特幣則更多了一層含義:比特幣對應著 一種劃時代的數字加密貨幣系統,其內容包含通信協議、激勵機制、實現代碼 與承載網絡等:

如何使用PHP開發比特幣詳解

事實上,比特幣是數十年來密碼學技術、分佈式計算等領域的集大成者, 它不是第一個出現的數字貨幣,但無疑是最成功的,一個洞察了人性的虛擬產品。

區塊鏈結構

比特幣是一個專用數據庫,它只保存一種類型的數據記錄 —— 交易,例如 張三轉給李四幾個幣,或者李四轉給王五幾個幣:

如何使用PHP開發比特幣詳解

一旦涉及到資金,大家都會變得慎重了。因此交易記錄最好在技術上可以保證 是不能篡改的,這樣出了問題可以翻翻老賬,這就要求賬本必須值得信賴。

比特幣採用一種特殊的數據結構區塊鏈/Blockchain來保障交易的不可篡改性, 每一個包含一批交易數據的區塊,同時也包含了前一個區塊的指紋:

如何使用PHP開發比特幣詳解

在比特幣中,一個區塊的指紋是使用密碼學中常見的哈希函數來實現的。 哈希函數可以將大塊數據壓縮成精簡的表示,而且可以保證如果精簡 的表示不同,那麼其對應的原始數據也不同。

例如,在上圖中如果12#區塊被攻擊者篡改,那麼它的哈希結果將不同於在 13#區塊中保存的其原始指紋,這使得識別篡改的區塊這一任務很容易,或者 說篡改的難度很大 —— 攻擊者必須同時修改12#之後的所有區塊才能保證 指紋校驗成功。

另一方面,如果攻擊者直接篡改14#區塊(我們假設這是最後一個塊),那麼 顯然是可行的,因為它缺乏之後更多區塊的保護。這引入了在比特幣中常用 的一個概念:交易的確認數/Confirms

交易一旦被確認打包到區塊中,它的確認數就是1,之後每增長一個區塊 則確認數加1。例如對於上圖中的標註交易,當鏈增長到14#塊時,該交易的 確認數就是3。

顯然一個交易的確認數越多,意味著攻擊者篡改交易的可能性越小。在比特幣 中的應用當中,交易的接收者通常需要在六個確認之後,才可以將該筆 交易視為成功。

去中心化機制

與當前流通的任何法幣都不同,比特幣是去中心化的,沒有一箇中央機構 來管理比特幣的發行與流通,因此比特幣網絡是一個典型的P2P網絡,在每個 (全)節點上都有完整的區塊鏈數據:

如何使用PHP開發比特幣詳解

在這樣的分佈式計算環境下,如何保證新的交易在各個節點區塊鏈中得以 一致的更新,就是經典的分佈式一致性問題了 —— 每個節點都有可能提交 新的交易,而不同節點提交的交易也可能不相同,到底以哪個節點為準?

解決這種問題的經典方法就是(動態)選舉一個決策者,其他節點複製 決策者的行為即可避免節點之間的不一致了。比特幣的解決思路也一樣, 不過它採用了一種類似於搶答的機制來動態選擇勝出的節點,由勝出的 節點負責出塊並打包交易 —— 所有節點都同時求解同一個問題,最先得到結果 的節點獲勝並獲得出塊權利,其他節點則轉而求解下一次出塊的問題:

如何使用PHP開發比特幣詳解

比特幣給出的問題不可以通過解析方法求解,節點必須在所有的可能 結果中暴力嘗試求解,由於勝出的節點可以獲得比特幣獎勵,使得 節點旳動機和行為頗為類似於淘金的西部牛仔,因此這一求解過程被 稱為挖礦/Mining

理論上每個節點都有獲勝的概率,但顯然,在同樣的時間內,計算力強大的 節點會比其他節點嘗試的機會更多,因此獲勝的概率也越大 —— 在這種搶答機制下, 算力代替了智力,而這種依賴於暴力求解問題從而達成節點一致性的共識算法 被稱為

工作量證明/Proof Of Work

課程內容

本課程適合於希望開發比特幣應用的PHP工程師,內容涵蓋比特幣的基本 概念、工作原理、應用開發接口、離線密鑰管理、分層確定性錢包以及 裸交易等諸多關鍵知識點。

第一章 比特幣概述

主要介紹比特幣的基本概念和核心工作原理。

第二章 Hi,比特幣

這一章主要介紹如何使用現有軟件進行比特幣的操作,例如創建地址、轉賬、 查詢餘額、瀏覽區塊等,同時介紹比特幣應用中的核心概念,如錢包、交易、UTXO等。

第三章 使用RPC訪問比特幣網絡

這一章主要介紹如何在程序代碼中利用節點軟件的RPC API接口訪問比特幣 網絡,進行轉賬、地址創建、查詢餘額等操作,同時給出了一種簡單的 在網站中支持比特幣支付的方案。

第四章 自己管理密鑰與地址

這一章主要介紹如何離線管理密鑰與地址,並詳細講解比特幣中的腳本以及 其與地址、身份驗證之間的關係。如果你希望在自己的應用中增加類似於 錢包的功能,這部分的內容將讓你收益匪淺。

第五章 使用分層確定性錢包

這一章主要介紹被廣泛使用的分層確定性錢包,並詳細講解如何在程序代碼 中加以應用。如果你需要管理大量的密鑰和地址,那麼分層確定性錢包應該 很有幫助。

第六章 離線構造裸交易

這一章主要介紹裸交易的作用,以及如何在程序代碼中創建裸交易。如果你 需要使用第三方節點來廣播你的比特幣交易,那麼裸交易就是你的唯一選擇。

課程地址在這裡:PHP比特幣開發教程

另外分享寫其他教程:

  • php以太坊,主要是介紹使用php進行智能合約開發交互,進行賬號創建、交易、轉賬、代幣開發以及過濾器和事件等內容。
  • EOS教程,本課程幫助你快速入門EOS區塊鏈去中心化應用的開發,內容涵蓋EOS工具鏈、賬戶與錢包、發行代幣、智能合約開發與部署、使用代碼與智能合約交互等核心知識點,最後綜合運用各知識點完成一個便籤DApp的開發。
  • web3j教程,主要是針對java和android程序員進行區塊鏈以太坊開發的web3j詳解。
  • 以太坊教程,主要介紹智能合約與dapp應用開發,適合入門。
  • 以太坊開發,主要是介紹使用node.js、mongodb、區塊鏈、ipfs實現去中心化電商DApp實戰,適合進階。
  • python以太坊,主要是針對python工程師使用web3.py進行區塊鏈以太坊開發的詳解。
  • C#以太坊,主要講解如何使用C#開發基於.Net的以太坊應用,包括賬戶管理、狀態與交易、智能合約開發與交互、過濾器和事件等。

© 著作權歸作者所有


分享到:


相關文章: