2019独角兽企业重金招聘Python工程师标准>>>

OmniTool开发包适用于为PHP应用快速增加对Omni Layer/USDT数字资产的支持能力,即支持使用自有Omni Layer节点的应用场景,也支持基于第三方API服务和离线裸交易的轻量级部署场景。下载地址:omni/usdt php开发包 。

1、OmniTool开发包简介

OmniTool开发包主要包含以下特性:

  • 完善的Omni Layer节点RPC封装
  • 支持利用自有节点或第三方服务获取指定地址的utxo集合
  • 支持离线生成omni代币转账裸交易
  • 支持利用自有节点或第三方服务广播裸交易

OmniTool支持本地部署的Omnicored节点,也支持blockchain.info、btc.com等提供的开放API,要增加对其他第三方服务的支持也非常简单,只需要参考代码实现如下接口:

  • UtxoCollectorInterface:utxo收集器
  • UtxoSelectorInterface:utxo筛选器
  • BroadcasterInterface:裸交易广播器
  • ExplorerInterface:数据查询接口

OmniTool软件包运行在**Php 7.1+**环境下,当前版本1.0.0,主要类/接口及关系如下图所示:

OmniTool的主要代码文件清单参见:http://sc.hubwiz.com/codebag/omni-php-lib/

2、RpcClient类使用说明

RpcClient类封装了Omni Layer的RPC接口协议。创建RpcClient对象时,需要传入包含有效身份信息的节点RPC URL。例如,假设安装在本机的omnicored节点软件配置如下:

  • rpcuser:user
  • rpcpassword:123456
  • rpcport:8332

那么可以使用如下的代码来实例化RpcClient:

use \OmniTool\RpcClient;$client = new RpcClient('http://user:123456@localhost:8332'   /*节点RPC接口的URL*/);

Omni Core节点在Bitcoin原有的RPC接口之外,扩充了额外的接口用来操作Omni层的数据,这些扩展的RPC接口采用omni_前缀以区隔于Bitcoin的原有RPC接口。为了便于区隔这两层的RPC调用,RpcClient引入了协议子模块的概念,将Bitcoin的原始RPC接口和Omni的扩展RPC接口分别挂接到btc子模块和omni子模块。

例如,获取某个地址的USDT代币余额需要使用Omni层的omni_getbalance调用,这个RPC调用对应于RpcClient实例的omni子模块的getBalance()方法。下面的代码获取地址1EXoDusjGwvnjZUyKkxZ4UHEf77z6A5S4P的USDT(资产ID:31)余额:

$ret = $client->omni->getBalance('1EXoDusjGwvnjZUyKkxZ4UHEf77z6A5S4P',   /*地址*/31                                      /*资产ID:USDT*/);

类似的,可以使用omni_send调用来执行简单的USDT转账,这个调用对应于RpcClient实例的omni子模块的send()方法。下面的代码从地址3M9qvHKtgARhqcMtM5cRT9VaiDJ5PSfQGY向地址37FaKponF7zqoMLUjEiko25pDiuVH5YLEa 转入100.0个USDT代币:

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

原有的bitoin层的RPC接口则可以通过RpcClient的btc子模块来访问。例如,使用listunspent调用来获取本地节点中指定地址的utxo:

$ret = $client->btc->listUnspent(6,                                        /*最小确认数*/999999,                                   /*最大确认数*/['mgnucj8nYqdrPFh2JfZSB1NmUThUGnmsqe']    /*地址清单*/  );

开发包中的demo/rpc-demo.php示例代码使用RpcClient类完整演示了在Omni层的代币发行与转账功能,如果你计划搭建自己的Omni Core节点,相信这个示例会有很大帮助。

3、Wallet类使用说明

如果不愿意搭建自己的Omni Core节点,而是希望基于第三方API为自己的PHP应用增加对Omni Layer/USDT的支持,那么最简单的方法是使用离线交易的入口类Wallet

Wallet类的主要作用是根据创建并广播Omni代币转账裸交易或比特币转账裸交易,它的基本使用步骤如下:

  • 使用Wallet::cloud()静态方法创建一个支持云端API服务的Wallet实例
  • 使用addKey()方法将必要的私钥加入该Wallet实例,例如转出地址的私钥,因为Wallet需要利用私钥对裸交易进行签名
  • 使用omniSendTx()方法生成Omni代币转账裸交易,或者使用btcSendTx()方法比特币转账裸交易
  • 使用broadcast()方法广播裸交易

3.1 Omni代币转账

使用Wallet实现的Omni代币转账示例代码如下,说明见注释:

<?php
require('../vendor/autoload.php');use OmniTool\Wallet;                              /*引入开发包*/$wallet = Wallet::cloud('./demo.wallet',                      /*钱包文件地址,自动创建*/'testnet'                             /*网络ID*/);
$prvKey = '4aec8e45106....00d5c5af494a4e05b';     /*私钥:16进制字符串*/
$wallet->addKey($prvKey);                         /*将私钥加入钱包,只需加入一次*/$addressList = $wallet->getAddressList();         /*返回钱包管理的所有地址,数组*/$rawtx = $wallet->omniSendTx($addressList[0],                      /*发送方地址,私钥必须已经加入钱包*/'mgYPLmNuZymK...e2XUNF6VFnT',         /*接收方地址*/2,                                    /*转账OMNI代币ID,2:TOMN*/'0.000001'                            /*转账OMNI代币数量*/);$ret = $wallet->broadcast($rawtx);                /*广播OMNI裸交易*/
var_dump($ret);

注意:

  • Wallet实例利用钱包中的私钥生成地址列表,并利用这些地址从第三方服务获取utxo信息。 因此需要钱包中 的私钥对应地址在链上有utxo存在,Wallet对象才能够成功构造裸交易。
  • 转账目标地址应当与创建Wallet对象时指定的链ID一致,例如mainnet的p2pkh地址,前缀应当为1

3.2 指定Omni交易的手续费支付地址

在Omni协议层不需要支付交易手续费,但是Omni交易所嵌入的比特币交易依然需要支付手续费。默认情况下omniSendTx()方法使用发送方地址支付比特币交易手续费,但可以传入额外的参数来指定其他地址支付交易手续费,当你的PHP应用需要实现多账户归集功能时,使用统一的手续费支付地址会更容易管理一些。

例如,下面的代码使用地址mnRo8JyTHDd5NxRb3UvGbAhCBPQTQ4UZ8W支付omni交易的手续费:

$rawtx = $wallet->omniSendTx($addressList[0],                      /*发送方地址,私钥必须已经加入钱包*/'mgYPLmNuZymK...e2XUNF6VFnT',         /*接收方地址*/2,                                    /*转账OMNI代币ID,2:TOMN*/'0.000001',                           /*转账OMNI代币数量*/'mnRo8JyTHDd5...CBPQTQ4UZ8W'          /*交易手续费支付地址*/);

注意:

  • 即使指定了余额充足的手续费支付地址,Omni交易的发送方依然必须有微量的比特币 余额(546 SATOSHI),因为Omni协议需要交易发送方至少有一个可用UTXO。
  • 手续费支付地址同时也是找零地址,多余的比特币将返回至该地址

3.3 指定Omni交易的比特币转账数量

由于Omni交易要求发送方必须有可用的UTXO,因此为了便于接收Omni代币的地址可以继续流通所持有的Omni代币,omniSendTx()方法在默认情况下将向接收方地址转入微量的比特币(546 SATOSHI),可以在调用该方法时修改这个默认数值。

例如,下面的代码转入接收方1000个SATOSHI:

$rawtx = $wallet->omniSendTx($addressList[0],                      /*发送方地址,私钥必须已经加入钱包*/'mgYPLmNuZymK...e2XUNF6VFnT',         /*接收方地址2,                                    /*转账OMNI代币ID,2:TOMN*/'0.000001',                           /*转账OMNI代币数量*/'mnRo8JyTHDd5...CBPQTQ4UZ8W',         /*交易手续费支付地址*/1000                                  /*转账比特币数量,单位: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],                /*发送方地址*/'moneyqMan7u...8qVrc9ikLP',     /*接收方地址*/1000,                           /*转账比特币数量,单位:SATOSHI*/500                             /*手续费,单位:SATOSHI*/);
echo 'btc rawtx => ' . $rawtx . PHP_EOL;$ret = $wallet->broadcast($rawtx);                  /*广播裸交易*/

默认情况下,btcSendTx()使用发送方地址作为找零地址,也可以在调用时指定其他地址作为找零地址,例如,下面的代码创建一个新地址接收找零:

$changeAddress = $wallet->getNewAddress();          /*创建新地址*/
$rawtx = $wallet->btcSendTx($addressList[0],                /*发送方地址*/'moneyqMan7u...8qVrc9ikLP',     /*接收方地址*/1000,                           /*转账比特币数量,单位:SATOSHI*/500,                            /*手续费,单位:SATOSHI*/$changeAddress                  /*找零地址*/);

4、UTXO收集器

OmniTool使用接口UtxoCollectorInterface来约定UTXO的收集功能。该接口的实现需要支持获取指定地址的候选UTXO集合,可指定多个地址。

接口方法:

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

参数$addressList用来声明要收集UTXO的地址清单,类型为数组。

当前实现类:

  • CloudUtxoCollector:基于blockchain.com的开放API实现的Utxo收集器
  • LocalUtxoCollector:基于omnicored节点RPC API实现的Utxo收集器

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

use OmniTool\CloudUtxoCollector;$collector = new CloudUtxoCollector('testnet'                       /*测试网*/);
$candidateBag = $collector->collect(['mi8BvbK73nDQ...KhfQ5ysKRn']   /*地址清单*/);

5、UTXO筛选器

OmniTool使用UtxoSelectorInterface来约定UTXO筛选功能。该接口的实现需要根据目标金额从候选UTXO中选择可用UTXO,并返回新的UtxoBag实例。

接口方法:

  • select($target,$candidates):选择可消费UTXO,返回UtxoBag对象

参数$target声明要达成的最低金额目标,单位:wei。

参数$candidates是候选的utxo集合,通常是UtxoCollectorInterface实现对象的collect()调用返回的UtxoBag对象。

当前实现类:

  • DefaultUtxoSelector

例如下面的代码使用DefaultUtxoSelector实例从候选UTXO中删选出至少100000 wei 的UTXO:

use OmniTool\DefaultUtxoSelector;$selector = new DefaultUtxoSelector();
$selectedBag = $selector->select(100000,                         /*最低目标金额*/$candidateBag                   /*候选UTXO集合*/);

考虑到UTXO的不可分割性,筛选出的若干UTXO的总和,有可能超过目标金额。可以使用UtxoBag实例的getTotal()方法查看集合中的UTXO总额:

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

6、裸交易广播器

OmniTool使用BroadcasterInterface来约定裸交易广播的功能。该接口的实现应当将裸交易广播到Omni网络中。

接口方法:

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

参数$rawtx用来声明要广播的裸交易,类型为16进制字符串。

当前实现类:

  • CloudBroadcaster
  • LocalBroadcaster

例如,下面的代码使用CloudBroadcaster将裸交易码流广播到Omni网络中:

use OmniTool\CloudBroadcaster;$broadcaster = new CloudBroadcaster('testnet'                     /*测试网*/);
$ret = $broadcaster->broadcast('01000000011da9283b4...59f58488ac00000000'  /*裸交易*/);

7、数据查询接口

OmniTool使用ExplorerInterface来约定Omni数据查询功能。

接口方法:

  • getBtcBalance($address):查询指定地址的比特币余额
  • getOmniBalance($address,$propertyId):查询指定地址的Omni代币余额

当前实现类:

  • 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;

如果你想学习区块链并在Blockchain Technologies建立职业生涯,那么请查看我们分享的一些以太坊、比特币、EOS、Fabric、Tendermint等区块链相关的交互式在线编程实战教程:

  • java以太坊开发教程,主要是针对java和android程序员进行区块链以太坊开发的web3j详解。
  • python以太坊,主要是针对python工程师使用web3.py进行区块链以太坊开发的详解。
  • php以太坊,主要是介绍使用php进行智能合约开发交互,进行账号创建、交易、转账、代币开发以及过滤器和交易等内容。
  • 以太坊入门教程,主要介绍智能合约与dapp应用开发,适合入门。
  • 以太坊开发进阶教程,主要是介绍使用node.js、mongodb、区块链、ipfs实现去中心化电商DApp实战,适合进阶。
  • ERC721以太坊通证实战,课程以一个数字艺术品创作与分享DApp的实战开发为主线,深入讲解以太坊非同质化通证的概念、标准与开发方案。内容包含ERC-721标准的自主实现,讲解OpenZeppelin合约代码库二次开发,实战项目采用Truffle,IPFS,实现了通证以及去中心化的通证交易所。
  • C#以太坊,主要讲解如何使用C#开发基于.Net的以太坊应用,包括账户管理、状态与交易、智能合约开发与交互、过滤器和交易等。
  • java比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Java代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Java工程师不可多得的比特币开发学习课程。
  • php比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在Php代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是Php工程师不可多得的比特币开发学习课程。
  • c#比特币开发教程,本课程面向初学者,内容即涵盖比特币的核心概念,例如区块链存储、去中心化共识机制、密钥与脚本、交易与UTXO等,同时也详细讲解如何在C#代码中集成比特币支持功能,例如创建地址、管理钱包、构造裸交易等,是C#工程师不可多得的比特币开发学习课程。
  • EOS入门教程,本课程帮助你快速入门EOS区块链去中心化应用的开发,内容涵盖EOS工具链、账户与钱包、发行代币、智能合约开发与部署、使用代码与智能合约交互等核心知识点,最后综合运用各知识点完成一个便签DApp的开发。
  • 深入浅出玩转EOS钱包开发,本课程以手机EOS钱包的完整开发过程为主线,深入学习EOS区块链应用开发,课程内容即涵盖账户、计算资源、智能合约、动作与交易等EOS区块链的核心概念,同时也讲解如何使用eosjs和eosjs-ecc开发包访问EOS区块链,以及如何在React前端应用中集成对EOS区块链的支持。课程内容深入浅出,非常适合前端工程师深入学习EOS区块链应用开发。
  • Hyperledger Fabric 区块链开发详解,本课程面向初学者,内容即包含Hyperledger Fabric的身份证书与MSP服务、权限策略、信道配置与启动、链码通信接口等核心概念,也包含Fabric网络设计、nodejs链码与应用开发的操作实践,是Nodejs工程师学习Fabric区块链开发的最佳选择。
  • Hyperledger Fabric java 区块链开发详解,课程面向初学者,内容即包含Hyperledger Fabric的身份证书与MSP服务、权限策略、信道配置与启动、链码通信接口等核心概念,也包含Fabric网络设计、java链码与应用开发的操作实践,是java工程师学习Fabric区块链开发的最佳选择。
  • tendermint区块链开发详解,本课程适合希望使用tendermint进行区块链开发的工程师,课程内容即包括tendermint应用开发模型中的核心概念,例如ABCI接口、默克尔树、多版本状态库等,也包括代币发行等丰富的实操代码,是go语言工程师快速入门区块链开发的最佳选择。

转载于:https://my.oschina.net/u/3794778/blog/3058997

USDT PHP开发包OmniTool简介相关推荐

  1. 公文识别开发包软件简介

    公文识别开发包软件简介  公文OCR识别SDK开发包软件V12.0是一种光学字符识别(OCR)软件开发包(OCR SDK):OCR SDK12.0为软件开发人员.系统集成商.数据加工商(BPO).扫描 ...

  2. 文字识别OCR-SDK开发包技术简介

    综合OCR文字识别SDK软件 关键词:OCR SDK 12.0 文字识别 中文识别 日文识别 韩文识别 英文识别 藏文识别 维文识别 一.OCR SDK综合文字识别软件简介 OCR SDK综合文字识别 ...

  3. java json开发包 fastjson 简介

    Json是一种轻量级的数据交换格式,采用一种"键:值"对的文本格式来存储和表示数据,在系统交换数据过程中常常被使用,是一种理想的数据交换语言.在使用Java做Web开发时,不可避免 ...

  4. HTML网页截图工具开发包CutyCapt简介

    CutyCapt是基于Qt实现的跨平台的将HTML网页转化成矢量图形和位图图像格式的命令行工具(比如,SVG, PDF, PS, PNG, JPEG, TIFF, GIF等)  (1)在Windows ...

  5. Omni/USDT钱包对接PHP开发包

    OmniTool开发包适用于为PHP应用快速增加对Omni Layer/USDT数字资产的支持能力,即支持使用自有Omni Layer节点的应用场景,也支持基于第三方API服务和离线裸交易的轻量级部署 ...

  6. USDT对接专用PHP开发包

    OmniTool开发包适用于为PHP应用快速增加对Omni Layer/USDT数字资产的支持能力,即支持使用自有Omni Layer节点的应用场景,也支持基于第三方API服务和离线裸交易的轻量级部署 ...

  7. 公文OCR开发包软件

    公文OCR开发包软件 关键词:OCR SDK 12.0 公文识别开发包 档案识别SDK 日文识别OCR 韩文OCR识别 英文识别 藏文识别 维文识别 公文OCR开发包软件简介  公文OCR开发包软件V ...

  8. 公文识别SDK开发包

    公文识别SDK开发包软件简介  公文识别SDK开发包软件V12.0是一种光学字符识别(OCR)软件开发包(OCR SDK):OCR SDK12.0为软件开发人员.系统集成商.数据加工商(BPO).扫描 ...

  9. 公文识别OCR开发包软件

    公文识别OCR开发包软件简介  公文识别OCR开发包软件V12.0是一种光学字符识别(OCR)软件开发包(OCR SDK):OCR SDK12.0为软件开发人员.系统集成商.数据加工商(BPO).扫描 ...

最新文章

  1. java 字母图形_Java字母图形
  2. 875. 爱吃香蕉的珂珂(二分)
  3. PropertyGrid 控件使用方法
  4. 1539. 第 k 个缺失的正整数
  5. 跳过php学thinkphp,PHP学习-ThinkPHP《从入门到放弃》(六)
  6. 服务器无法继续该事务 3400000006 错误原因--JAVA调用SQLSERVER存储过程时过程发生异常内部事务未
  7. mysql 修改字段编码_mysql修改数据库编码字段编码
  8. java如何把方法封装成接口,RxJava配合Retrofit实现网络封装
  9. 面试官:这货一听就是一个水货...
  10. php格式转换rar,如何在PHP中创建压缩的RAR文件?
  11. l298n使能端跳线帽_L298N 驱动模块的应用
  12. 操作系统——概念、功能、特征及发展分类
  13. oracle数据库刷内存语句,Oracle数据库内存助手
  14. Android adb脚本文件神器
  15. Redis - 听说 Dragonfly 宣称比我快 25 倍
  16. pycharm报错: with exit code -1073740791 (0xC0000409)
  17. 淘宝网店如何提升无线端宝贝权重,抢占更多无线流量?
  18. angular设置路由实现无刷新跳转
  19. SPI 通信协议 最详细解读!!!
  20. 在使用计算机时可以用什么键关机,电脑死机按什么键关机重启

热门文章

  1. jQuery -- 光阴似箭(二):jQuery效果的使用
  2. 32位系统上开发的Access为数据库的程序在64位机器上运行出错的解决办法
  3. Fielding 博士论文阅读笔记(一)
  4. Visual C++ 6.0工程中.clw、.ncb、.aps、.aps文件
  5. Codeforces Beta Round #91 div.2 滑稽场 A-D
  6. 三相异步变频调速电机宠坏配套设备:偶遇知己此生足矣!
  7. ADODB.Connection 错误 '800a0e7a' 处理
  8. python线程池的实现
  9. Omni Recover 2.9.5.2 iPhone数据恢复软件
  10. 亚阈值区和深三极管区讲解