溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何理解Omni和USDT PHP開發(fā)包

發(fā)布時間:2021-11-23 10:12:48 來源:億速云 閱讀:171 作者:柒染 欄目:互聯(lián)網(wǎng)科技

這篇文章將為大家詳細講解有關如何理解Omni和USDT PHP開發(fā)包,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。

OmniTool開發(fā)包適用于為PHP應用快速增加對Omni Layer/USDT數(shù)字資產(chǎn)的支持能力,即支持使用自有Omni Layer節(jié)點的應用場景,也支持基于第三方API服務和離線裸交易的輕量級部署場景。

1、OmniTool開發(fā)包簡介

OmniTool開發(fā)包主要包含以下特性:

  • 完善的Omni Layer節(jié)點RPC封裝

  • 支持利用自有節(jié)點或第三方服務獲取指定地址的utxo集合

  • 支持離線生成omni代幣轉賬裸交易

  • 支持利用自有節(jié)點或第三方服務廣播裸交易

OmniTool支持本地部署的Omnicored節(jié)點,也支持blockchain.info、btc.com等提供的開放API,要增加對其他第三方服務的支持也非常簡單,只需要參考代碼實現(xiàn)如下接口:

  • UtxoCollectorInterface:utxo收集器

  • UtxoSelectorInterface:utxo篩選器

  • BroadcasterInterface:裸交易廣播器

  • ExplorerInterface:數(shù)據(jù)查詢接口

OmniTool軟件包運行在**Php 7.1+**環(huán)境下,當前版本1.0.0,主要類/接口及關系如下圖所示:

如何理解Omni和USDT PHP開發(fā)包

OmniTool的主要代碼文件清單如下:

  • 代碼文件 說明

  • omni.php/src/RpcClient.php Omni Layer的RPC協(xié)議封裝類

  • omni.php/src/RpcModule.php Omni Layer的RPC協(xié)議分模塊訪問語法糖

  • omni.php/src/protocol-spec.json Omni Layer協(xié)議描述元信息

  • omni.php/src/SerializeBuffer.php Omni Layer協(xié)議序列化緩沖區(qū)

  • omni.php/src/PayloadFactory.php Omni Layer協(xié)議載荷工廠類

  • omni.php/src/Utxo.php 未消費交易輸出類

  • omni.php/src/UtxoBag.php Utxo集合類

  • omni.php/src/UtxoCollectorInterface.php Utxo收集器接口

  • omni.php/src/LocalUtxoCollector.php 基于OmniCore節(jié)點的Utxo收集器實現(xiàn)

  • omni.php/src/CloudUtxoCollector.php 基于第三方服務的Utxo收集器實現(xiàn)

  • omni.php/src/UtxoSelectorInterface.php Utxo篩選器接口

  • omni.php/src/DefaultUtxoSelector.php 默認的Utxo篩選器實現(xiàn)

  • omni.php/src/BroadcasterInterface.php 裸交易廣播器接口

  • omni.php/src/LocalBroadcaster.php 基于OmniCore節(jié)點的裸交易廣播器實現(xiàn)

  • omni.php/src/CloudBroadcaster.php 基于第三方服務的裸交易廣播器實現(xiàn)

  • omni.php/src/ExplorerInterface.php 數(shù)據(jù)查詢接口

  • omni.php/src/CloudExplorer.php 基于第三方服務的數(shù)據(jù)查詢接口實現(xiàn)

  • omni.php/src/LocalExplorer.php 基于OmniCore節(jié)點的數(shù)據(jù)查詢接口實現(xiàn)

  • omni.php/src/Utils.php 常用輔助函數(shù)

  • omni.php/src/Wallet.php 離線錢包類

  • demo/rpc-demo.php RpcClient使用示例,完整實現(xiàn)OMNI代幣的發(fā)行與轉賬

  • demo/omni-tx-cloud.php 創(chuàng)建并廣播Omni代幣轉賬裸交易,使用第三方云服務API

  • demo/omni-tx-local.php 創(chuàng)建并廣播Omni代幣轉賬裸交易,使用自有節(jié)點

  • demo/btc-tx-cloud.php 創(chuàng)建并廣播比特幣轉賬裸交易,使用第三方云服務API

  • demo/btc-tx-local.php 創(chuàng)建并廣播比特幣轉賬裸交易,使用自有節(jié)點

  • demo/explorer-cloud.php 查詢指定的地址比特幣余額/Omni代幣余額,使用第三方云服務API

  • demo/explorer-local.php 查詢指定地址的比特幣余額/Omni代幣余額,使用自有節(jié)點

  • demo/wallet-init.php 本地錢包初始化

  • demo/wallet-demo.php 錢包載入、裸交易構造和廣播

  • vendor 第三方依賴包目錄

  • composer.json composer配置文件

2、RpcClient類使用說明

RpcClient類封裝了Omni Layer的RPC接口協(xié)議。創(chuàng)建RpcClient對象時,需要傳入 包含有效身份信息的節(jié)點RPC URL。例如,假設安裝在本機的omnicored節(jié)點軟件配置如下:

  • rpcuser:user

  • rpcpassword:123456

  • rpcport:8332

那么可以使用如下的代碼來實例化RpcClient:

use \OmniTool\RpcClient;

$client = new RpcClient(
            'http://user:123456@localhost:8332'   /*節(jié)點RPC接口的URL*/
          );

Omni Core節(jié)點在Bitcoin原有的RPC接口之外,擴充了額外的接口用來操作Omni層的數(shù)據(jù),這些擴展的RPC接口采用omni_前綴以區(qū)隔于Bitcoin的原有RPC接口。為了便于區(qū)隔這兩層的RPC調用,RpcClient引入了協(xié)議子模塊的概念,將Bitcoin的原始RPC接口和Omni的擴展RPC接口分別掛接到btc子模塊和omni子模塊。

例如,獲取某個地址的USDT代幣余額需要使用Omni層的omni_getbalance調用,這個RPC調用對應于RpcClient實例的omni子模塊的getBalance()方法。下面的代碼獲取地址1EXoDusjGwvnjZUyKkxZ4UHEf77z6A5S4P的USDT(資產(chǎn)ID:31)余額:

$ret = $client->omni->getBalance(
          '1EXoDusjGwvnjZUyKkxZ4UHEf77z6A5S4P',   /*地址*/
          31                                      /*資產(chǎn)ID:USDT*/
       );

類似的,可以使用omni_send調用來執(zhí)行簡單的USDT轉賬,這個調用對應于RpcClient實例的omni子模塊的send()方法。下面的代碼從地址3M9qvHKtgARhqcMtM5cRT9VaiDJ5PSfQGY向地址37FaKponF7zqoMLUjEiko25pDiuVH5YLEa轉入100.0個USDT代幣:

$ret = $client->omni->send(
          '3M9qvHKtgARhqcMtM5cRT9VaiDJ5PSfQGY',    /*代幣轉出地址*/
          '37FaKponF7zqoMLUjEiko25pDiuVH5YLEa',    /*代幣轉入地址*/
          31,                                      /*代幣ID:USDT*/
          "100.00"                                 /*轉移的代幣數(shù)量*/
       );

原有的bitoin層的RPC接口則可以通過RpcClient的btc子模塊來訪問。例如,使用listunspent調用來獲取本地節(jié)點中指定地址的utxo:

$ret = $client->btc->listUnspent(
          6,                                        /*最小確認數(shù)*/
          999999,                                   /*最大確認數(shù)*/
          ['mgnucj8nYqdrPFh3JfZSB1NmUThUGnmsqe']    /*地址清單*/  
       );

開發(fā)包中的demo/rpc-demo.php示例代碼使用RpcClient類完整演示了在Omni層的代幣發(fā)行與轉賬功能,如果你計劃搭建自己的Omni Core節(jié)點,相信這個示例會有很大幫助。

3、Wallet類使用說明

如果不愿意搭建自己的Omni Core節(jié)點,而是希望基于第三方API為自己的PHP應用增加對Omni Layer/USDT的支持,那么最簡單的方法是使用離線交易的入口類Wallet。

Wallet類的主要作用是根據(jù)創(chuàng)建并廣播Omni代幣轉賬裸交易或比特幣轉賬裸交易,它的基本使用步驟如下:

  • 使用Wallet::cloud()靜態(tài)方法創(chuàng)建一個支持云端API服務的Wallet實例

  • 使用addKey()方法將必要的私鑰加入該Wallet實例,例如轉出地址的私鑰,因為Wallet需要利用私鑰對裸交易進行簽名

  • 使用omniSendTx()方法生成Omni代幣轉賬裸交易,或者使用btcSendTx()方法比特幣轉賬裸交易

  • 使用broadcast()方法廣播裸交易

3.1 Omni代幣轉賬

使用Wallet實現(xiàn)的Omni代幣轉賬示例代碼如下,說明見注釋:

<?php
require('../vendor/autoload.php');

use OmniTool\Wallet;                              /*引入開發(fā)包*/

$wallet = Wallet::cloud(
            './demo.wallet',                      /*錢包文件地址,自動創(chuàng)建*/
            'testnet'                             /*網(wǎng)絡ID*/
          );
$prvKey = '4aec8e45106....00d5c5af494a4e05b';     /*私鑰:16進制字符串*/            
$wallet->addKey($prvKey);                         /*將私鑰加入錢包,只需加入一次*/

$addressList = $wallet->getAddressList();         /*返回錢包管理的所有地址,數(shù)組*/

$rawtx = $wallet->omniSendTx(
            $addressList[0],                      /*發(fā)送方地址,私鑰必須已經(jīng)加入錢包*/
            'mgYPLmNuZymK...e2XUNF6VFnT',         /*接收方地址*/
            2,                                    /*轉賬OMNI代幣ID,2:TOMN*/
            '0.000001'                            /*轉賬OMNI代幣數(shù)量*/
         );

$ret = $wallet->broadcast($rawtx);                /*廣播OMNI裸交易*/
var_dump($ret);

注意:

  • Wallet實例利用錢包中的私鑰生成地址列表,并利用這些地址從第三方服務獲取utxo信息。因此需要錢包中的私鑰對應地址在鏈上有utxo存在,Wallet對象才能夠成功構造裸交易。

  • 轉賬目標地址應當與創(chuàng)建Wallet對象時指定的鏈ID一致,例如mainnet的p2pkh地址,前綴應當為1

3.2 指定Omni交易的手續(xù)費支付地址

在Omni協(xié)議層不需要支付交易手續(xù)費,但是Omni交易所嵌入的比特幣交易依然需要支付手續(xù)費。默認情況下omniSendTx()方法使用發(fā)送方地址支付比特幣交易手續(xù)費,但可以傳入額外的參數(shù)來指定其他地址支付交易手續(xù)費,當你的PHP應用需要實現(xiàn)多賬戶歸集功能時,使用統(tǒng)一的手續(xù)費支付地址會更容易管理一些。

例如,下面的代碼使用地址mnRo8JyTHDd5NxRb3UvGbAhCBPQTQ4UZ8W支付omni交易的手續(xù)費:

$rawtx = $wallet->omniSendTx(
            $addressList[0],                      /*發(fā)送方地址,私鑰必須已經(jīng)加入錢包*/
            'mgYPLmNuZymK...e2XUNF6VFnT',         /*接收方地址*/
            2,                                    /*轉賬OMNI代幣ID,2:TOMN*/
            '0.000001',                           /*轉賬OMNI代幣數(shù)量*/
            'mnRo8JyTHDd5...CBPQTQ4UZ8W'          /*交易手續(xù)費支付地址*/
         );

注意:

  • 即使指定了余額充足的手續(xù)費支付地址,Omni交易的發(fā)送方依然必須有微量的比特幣余額(546 SATOSHI),因為Omni協(xié)議需要交易發(fā)送方至少有一個可用UTXO。

  • 手續(xù)費支付地址同時也是找零地址,多余的比特幣將返回至該地址

3.3 指定Omni交易的比特幣轉賬數(shù)量

由于Omni交易要求發(fā)送方必須有可用的UTXO,因此為了便于接收Omni代幣的地址可以繼續(xù)流通所持有的Omni代幣,omniSendTx()方法在默認情況下將向接收方地址轉入微量的比特幣(546 SATOSHI),可以在調用該方法時修改這個默認數(shù)值。

例如,下面的代碼轉入接收方1000個SATOSHI:

$rawtx = $wallet->omniSendTx(
            $addressList[0],                      /*發(fā)送方地址,私鑰必須已經(jīng)加入錢包*/
            'mgYPLmNuZymK...e2XUNF6VFnT',         /*接收方地址
            2,                                    /*轉賬OMNI代幣ID,2:TOMN*/
            '0.000001',                           /*轉賬OMNI代幣數(shù)量*/
            'mnRo8JyTHDd5...CBPQTQ4UZ8W',         /*交易手續(xù)費支付地址*/
            1000                                  /*轉賬比特幣數(shù)量,單位:SATOSHI*/
         );
3.4 比特幣轉賬

OmniTool也支持比特幣轉賬裸交易的生成與廣播。

例如,下面的代碼從錢包的第一個地址向指定接受地址轉入1000個SATOSHI:

<?php
require('../vendor/autoload.php');

use OmniTool\Wallet;

$wallet = Wallet::cloud('./demo.wallet','testnet');
$addressList = $wallet->getAddressList();

$rawtx = $wallet->btcSendTx(
                    $addressList[0],                /*發(fā)送方地址*/
                    'moneyqMan7u...8qVrc9ikLP',     /*接收方地址*/
                    1000,                           /*轉賬比特幣數(shù)量,單位:SATOSHI*/
                    500                             /*手續(xù)費,單位:SATOSHI*/
                  );                       
echo 'btc rawtx => ' . $rawtx . PHP_EOL;

$ret = $wallet->broadcast($rawtx);                  /*廣播裸交易*/

默認情況下,btcSendTx()使用發(fā)送方地址作為找零地址,也可以在調用時指定其他地址作為找零地址,例如,下面的代碼創(chuàng)建一個新地址接收找零:

$changeAddress = $wallet->getNewAddress();          /*創(chuàng)建新地址*/
$rawtx = $wallet->btcSendTx(
                    $addressList[0],                /*發(fā)送方地址*/
                    'moneyqMan7u...8qVrc9ikLP',     /*接收方地址*/
                    1000,                           /*轉賬比特幣數(shù)量,單位:SATOSHI*/
                    500,                            /*手續(xù)費,單位:SATOSHI*/
                    $changeAddress                  /*找零地址*/
                  );

4、UTXO收集器

OmniTool使用接口UtxoCollectorInterface來約定UTXO的收集功能。該接口的實現(xiàn)需要支持獲取指定地址的候選UTXO集合,可指定多個地址。

接口方法:

  • collect($addressList):提取并返回候選UTXO集合

參數(shù)$addressList用來聲明要收集UTXO的地址清單,類型為數(shù)組。

當前實現(xiàn)類:

  • CloudUtxoCollector:基于blockchain.com的開放API實現(xiàn)的Utxo收集器

  • LocalUtxoCollector:基于omnicored節(jié)點RPC API實現(xiàn)的Utxo收集器

例如,下面的代碼使用CloudUtxoCollector獲取地址mi8BvbK73nDQfaN3acpaFGYQKhfQ5ysKRn的UTXO:

use OmniTool\CloudUtxoCollector;

$collector = new CloudUtxoCollector(
                    'testnet'                       /*測試網(wǎng)*/
                 );
$candidateBag = $collector->collect(
                    ['mi8BvbK73nDQ...KhfQ5ysKRn']   /*地址清單*/
                );

5、UTXO篩選器

OmniTool使用UtxoSelectorInterface來約定UTXO篩選功能。該接口的實現(xiàn)需要根據(jù)目標金額從候選UTXO中選擇可用UTXO,并返回新的UtxoBag實例。

接口方法:

  • select($target,$candidates):選擇可消費UTXO,返回UtxoBag對象

參數(shù)$target聲明要達成的最低金額目標,單位:wei。

參數(shù)$candidates是候選的utxo集合,通常是UtxoCollectorInterface實現(xiàn)對象的collect()調用返回的UtxoBag對象。

當前實現(xiàn)類:

  • DefaultUtxoSelector

例如下面的代碼使用DefaultUtxoSelector實例從候選UTXO中刪選出至少100000 wei 的UTXO:

use OmniTool\DefaultUtxoSelector;

$selector = new DefaultUtxoSelector();
$selectedBag = $selector->select(
                  100000,                         /*最低目標金額*/
                  $candidateBag                   /*候選UTXO集合*/
               );

考慮到UTXO的不可分割性,篩選出的若干UTXO的總和,有可能超過目標金額??梢允褂肬txoBag實例的getTotal()方法查看集合中的UTXO總額:

echo 'total wei in bag => ' . $selectedBag->getTotal() . PHP_EOL;

6、裸交易廣播器

OmniTool使用BroadcasterInterface來約定裸交易廣播的功能。該接口的實現(xiàn)應當將裸交易廣播到Omni網(wǎng)絡中。

接口方法:

  • broadcast($rawtx):廣播裸交易

參數(shù)$rawtx用來聲明要廣播的裸交易,類型為16進制字符串。

當前實現(xiàn)類:

  • CloudBroadcaster

  • LocalBroadcaster

例如,下面的代碼使用CloudBroadcaster將裸交易碼流廣播到Omni網(wǎng)絡中:

use OmniTool\CloudBroadcaster;

$broadcaster = new CloudBroadcaster(
                      'testnet'                     /*測試網(wǎng)*/
                   );
$ret = $broadcaster->broadcast(
        '01000000011da9283b4...59f58488ac00000000'  /*裸交易*/
       );

7、數(shù)據(jù)查詢接口

OmniTool使用ExplorerInterface來約定Omni數(shù)據(jù)查詢功能。

接口方法:

  • getBtcBalance($address):查詢指定地址的比特幣余額

  • getOmniBalance($address,$propertyId):查詢指定地址的Omni代幣余額

當前實現(xiàn)類:

  • CloudBroadcaster

  • LocalBroadcaster

例如,下面的代碼使用CloudExplorer查詢地址1Jekm8ZswQmDhLFMp9cuYb1Kcq26riFp6m的比特幣余額與USDT代幣余額:

use OmniTool\CloudExplorer;

$explorer = new CloudExplorer('mainnet');

$address = '1Jekm8ZswQmDhLFMp9cuYb1Kcq26riFp6m';

$balance = $explorer->getBtcBalance($address);
echo 'btc balance => ' . PHP_EOL;

$balance = $explorer->getOmniBalance($address,31);
echo 'usdt balance => ' . $balance['balance']. PHP_EOL;

如果你想學習區(qū)塊鏈并在Blockchain Technologies建立職業(yè)生涯,那么請查看我們分享的一些以太坊、比特幣、EOS、Fabric、Tendermint等區(qū)塊鏈相關的交互式在線編程實戰(zhàn)教程:

  • java以太坊開發(fā)教程,主要是針對java和android程序員進行區(qū)塊鏈以太坊開發(fā)的web3j詳解。

  • python以太坊,主要是針對python工程師使用web3.py進行區(qū)塊鏈以太坊開發(fā)的詳解。

  • php以太坊,主要是介紹使用php進行智能合約開發(fā)交互,進行賬號創(chuàng)建、交易、轉賬、代幣開發(fā)以及過濾器和交易等內容。

  • 以太坊入門教程,主要介紹智能合約與dapp應用開發(fā),適合入門。

  • 以太坊開發(fā)進階教程,主要是介紹使用node.js、mongodb、區(qū)塊鏈、ipfs實現(xiàn)去中心化電商DApp實戰(zhàn),適合進階。

  • ERC721以太坊通證實戰(zhàn),課程以一個數(shù)字藝術品創(chuàng)作與分享DApp的實戰(zhàn)開發(fā)為主線,深入講解以太坊非同質化通證的概念、標準與開發(fā)方案。內容包含ERC-721標準的自主實現(xiàn),講解OpenZeppelin合約代碼庫二次開發(fā),實戰(zhàn)項目采用Truffle,IPFS,實現(xiàn)了通證以及去中心化的通證交易所。

  • C#以太坊,主要講解如何使用C#開發(fā)基于.Net的以太坊應用,包括賬戶管理、狀態(tài)與交易、智能合約開發(fā)與交互、過濾器和交易等。

  • java比特幣開發(fā)教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區(qū)塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Java代碼中集成比特幣支持功能,例如創(chuàng)建地址、管理錢包、構造裸交易等,是Java工程師不可多得的比特幣開發(fā)學習課程。

  • php比特幣開發(fā)教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區(qū)塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在Php代碼中集成比特幣支持功能,例如創(chuàng)建地址、管理錢包、構造裸交易等,是Php工程師不可多得的比特幣開發(fā)學習課程。

  • c#比特幣開發(fā)教程,本課程面向初學者,內容即涵蓋比特幣的核心概念,例如區(qū)塊鏈存儲、去中心化共識機制、密鑰與腳本、交易與UTXO等,同時也詳細講解如何在C#代碼中集成比特幣支持功能,例如創(chuàng)建地址、管理錢包、構造裸交易等,是C#工程師不可多得的比特幣開發(fā)學習課程。

  • EOS入門教程,本課程幫助你快速入門EOS區(qū)塊鏈去中心化應用的開發(fā),內容涵蓋EOS工具鏈、賬戶與錢包、發(fā)行代幣、智能合約開發(fā)與部署、使用代碼與智能合約交互等核心知識點,最后綜合運用各知識點完成一個便簽DApp的開發(fā)。

  • 深入淺出玩轉EOS錢包開發(fā),本課程以手機EOS錢包的完整開發(fā)過程為主線,深入學習EOS區(qū)塊鏈應用開發(fā),課程內容即涵蓋賬戶、計算資源、智能合約、動作與交易等EOS區(qū)塊鏈的核心概念,同時也講解如何使用eosjs和eosjs-ecc開發(fā)包訪問EOS區(qū)塊鏈,以及如何在React前端應用中集成對EOS區(qū)塊鏈的支持。課程內容深入淺出,非常適合前端工程師深入學習EOS區(qū)塊鏈應用開發(fā)。

  • Hyperledger Fabric 區(qū)塊鏈開發(fā)詳解,本課程面向初學者,內容即包含Hyperledger Fabric的身份證書與MSP服務、權限策略、信道配置與啟動、鏈碼通信接口等核心概念,也包含F(xiàn)abric網(wǎng)絡設計、nodejs鏈碼與應用開發(fā)的操作實踐,是Nodejs工程師學習Fabric區(qū)塊鏈開發(fā)的最佳選擇。

  • Hyperledger Fabric java 區(qū)塊鏈開發(fā)詳解,課程面向初學者,內容即包含Hyperledger Fabric的身份證書與MSP服務、權限策略、信道配置與啟動、鏈碼通信接口等核心概念,也包含F(xiàn)abric網(wǎng)絡設計、java鏈碼與應用開發(fā)的操作實踐,是java工程師學習Fabric區(qū)塊鏈開發(fā)的最佳選擇。

  • tendermint區(qū)塊鏈開發(fā)詳解,本課程適合希望使用tendermint進行區(qū)塊鏈開發(fā)的工程師,課程內容即包括tendermint應用開發(fā)模型中的核心概念,例如ABCI接口、默克爾樹、多版本狀態(tài)庫等,也包括代幣發(fā)行等豐富的實操代碼,是go語言工程師快速入門區(qū)塊鏈開發(fā)的最佳選擇。

關于如何理解Omni和USDT PHP開發(fā)包就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內容(圖片、視頻和文字)以原創(chuàng)、轉載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內容。

AI