Skip to content

Latest commit

 

History

History
197 lines (167 loc) · 8.55 KB

docs.md

File metadata and controls

197 lines (167 loc) · 8.55 KB

其他系统对接TokenPay

也可参考仓库内现有的独角数卡插件对接

1. 创建TokenPay订单

URL: /CreateOrder

类型: POST
Content-Type: application/json

字段 类型 必填 说明
OutOrderId string 外部订单号
OrderUserKey string 支付用户标识,建议传用户联系方式或用户ID等能识别用户身份的字符串。使用动态地址时,会根据此字段关联收款地址,传递用户ID等,可以保证系统后续还会为此用户分配此地址。如需要每个订单一个新地址,可向此字段传递外部订单号
ActualAmount decimal 订单实际支付的法币金额,法币币种依据配置文件中的BaseCurrency决定,保留两位小数
Currency Enum,支持USDT_TRC20TRX 加密货币的币种,直接以原样字符串传递即可
PassThroughInfo 不限长度的任意字符串 在回调通知或订单信息中原样返回
NotifyUrl string? 异步通知URL
RedirectUrl string? 订单支付或过期后跳转的URL
Signature string 参数签名,参见下方参数签名生成规则

①示例POST参数

{
    "OutOrderId": "AJIHK72N34BR2CWG",
    "OrderUserKey": "[email protected]",
    "ActualAmount": 15,
    "Currency": "TRX",
    "NotifyUrl": "http://localhost:1011/pay/tokenpay/notify_url",
    "RedirectUrl": "http://localhost:1011/pay/tokenpay/return_url?order_id=AJIHK72N34BR2CWG"
}

②按照ASCII排序后拼接

ActualAmount=15&Currency=TRX&NotifyUrl=http://localhost:1011/pay/tokenpay/notify_url&[email protected]&OutOrderId=AJIHK72N34BR2CWG&RedirectUrl=http://localhost:1011/pay/tokenpay/return_url?order_id=AJIHK72N34BR2CWG

异步通知密钥为:666

拼接密钥后 ActualAmount=15&Currency=TRX&NotifyUrl=http://localhost:1011/pay/tokenpay/notify_url&[email protected]&OutOrderId=AJIHK72N34BR2CWG&RedirectUrl=http://localhost:1011/pay/tokenpay/return_url?order_id=AJIHK72N34BR2CWG666

③计算MD5

e9765880db6081496456283678e70152

④POST参数增加Signature

{
    "OutOrderId": "AJIHK72N34BR2CWG",
    "OrderUserKey": "[email protected]",
    "ActualAmount": 15,
    "Currency": "TRX",
    "NotifyUrl": "http://localhost:1011/pay/tokenpay/notify_url",
    "RedirectUrl": "http://localhost:1011/pay/tokenpay/return_url?order_id=AJIHK72N34BR2CWG",
    "Signature": "e9765880db6081496456283678e70152"
}

⑤返回数据示例

创建订单成功的返回示例

{
    "success": true,
    "message": "创建订单成功!",
    "data": "http://127.0.0.1:5000/Pay?Id=6324ddd2-4677-7914-0010-702806ae9766",
    "info": {
        "ActualAmount": "15",//法币金额
        "Amount": "227.34",//支付的区块链货币金额
        "BaseCurrency": "CNY",//法币币种
        "BlockChainName": "TRON",//付款区块链
        "CurrencyName": "TRX", //付款币种
        "ExpireTime": "2023-04-28 14:04:57", //付款过期时间
        "Id": "644bc479-df0c-3f1c-00fe-9cb3012b148b", //订单Id
        "OrderUserKey": "[email protected]", //用户识别Key
        "OutOrderId": "AJIHK72N34BR2CWG", //商户订单号
        "QrCodeBase64": "", //base64格式的图片
        "QrCodeLink": "http://127.0.0.1:5000/GetQrCode?Id=644bc479-df0c-3f1c-00fe-9cb3012b148b", //二维码图片链接,如需修改图片尺寸,可拼接参数 &Size=xxx, 这里的xxx为数字,表示图片宽高,默认为300
        "ToAddress": "TLUF41C386CMU1Wc8pTSCE4QaiZ2xkhTCb" //付款地址
    }
}

创建订单失败的返回示例

{
    "success": false,
    "message": "签名验证失败!"
}

2. TokenPay的异步回调参数

如接口返回的状态码不是200,或者响应的内容不是字符串ok,视为回调失败。
回调失败后将会在一分钟后重试,总共重试两次。

URL: 创建订单接口传递的NotifyUrl字段内的URL

类型: POST
Content-Type: application/json

字段 类型 说明
Id string TokenPay内部订单号
BlockTransactionId string 区块哈希
OutOrderId string 外部订单号,调用 创建订单 接口时传递的外部订单号
OrderUserKey string 支付用户标识,调用 创建订单 接口时传递的支付用户标识
PayTime string 支付时间,示例:2022-09-15 16:00:00
BlockchainName string 区块链名称
Currency string 币种,USDT_TRC20TRX等,如配置了EVMChains.json,原生币格式为EVM_[ChainNameEN]_[BaseCoin],ERC20代币格式为:EVM_[ChainNameEN]_[Erc20.Name]_[ERC20Name],如BSC的原生币为EVM_BSC_BNB,BSC的USDT代币为EVM_BSC_USDT_BEP20
CurrencyName string 币种名称
BaseCurrency string 法币币种,支持CNY、USD、EUR、GBP、AUD、HKD、TWD、SGD
Amount string 订单金额,此金额为法币BaseCurrency转换为Currency币种后的金额
ActualAmount string 订单金额,此金额为法币金额
FromAddress string 付款地址
ToAddress string 收款地址
Status int 状态 0 等待支付 1 已支付 2 订单过期
PassThroughInfo string 创建订单如提供了此字段,在回调通知或订单信息中会原样返回
PayAmount string 实际支付金额,新增动态金额功能时新增此字段
IsDynamicAmount int 是否是动态金额订单,新增动态金额功能时新增此字段
Signature string 签名,接口请务必验证此参数!!!将除Signature字段外的所有字段,按照字母升序排序,忽略没有值的字段,按顺序拼接为key1=value1&key2=value2形式,然后在末尾拼接上异步通知密钥,将此字符串计算MD5,即为签名。
重要说明 ---- 以上字段列表仅供参考,具体以实际传递的字段为准,实际字段数量可能会有增减,因此签名验证算法建议直接解析body内的json字符串,可参考 TokenPayController.php 中的 VerifySign

①示例POST参数

{
    "ActualAmount": "15",
    "Amount": "34.91",
    "BaseCurrency": "CNY",
    "BlockChainName": "TRON",
    "BlockTransactionId": "375859c36dc5f5d227b10912b5ec70d36dd34446028064956cb60cdbb74432f5",
    "Currency": "TRX",
    "CurrencyName": "TRX",
    "FromAddress": "TYYjzt6AWhe9hAg9DrhiYXEWKDksyohgQa",
    "Id": "63234df7-55bf-93fc-0010-67be493c0c27",
    "OutOrderId": "E6COE6FGZMO5AXSK",
    "PayTime": "2022-09-15 16:08:39",
    "Status": 1,
    "ToAddress": "TLUF41C386CMU1Wc8pTSCE4QaiZ2xkhTCb"
}

②按照ASCII排序后拼接

ActualAmount=15&Amount=34.91&BaseCurrency=CNY&BlockChainName=TRON&BlockTransactionId=375859c36dc5f5d227b10912b5ec70d36dd34446028064956cb60cdbb74432f5&Currency=TRX&CurrencyName=TRX&FromAddress=TYYjzt6AWhe9hAg9DrhiYXEWKDksyohgQa&Id=63234df7-55bf-93fc-0010-67be493c0c27&OutOrderId=E6COE6FGZMO5AXSK&PayTime=2022-09-15 16:08:39&Status=1&ToAddress=TLUF41C386CMU1Wc8pTSCE4QaiZ2xkhTCb

假设异步通知密钥为:666

拼接密钥后 ActualAmount=15&Amount=34.91&BaseCurrency=CNY&BlockChainName=TRON&BlockTransactionId=375859c36dc5f5d227b10912b5ec70d36dd34446028064956cb60cdbb74432f5&Currency=TRX&CurrencyName=TRX&FromAddress=TYYjzt6AWhe9hAg9DrhiYXEWKDksyohgQa&Id=63234df7-55bf-93fc-0010-67be493c0c27&OutOrderId=E6COE6FGZMO5AXSK&PayTime=2022-09-15 16:08:39&Status=1&ToAddress=TLUF41C386CMU1Wc8pTSCE4QaiZ2xkhTCb666

③计算MD5

a8f9d179a8d2798c8b5bb90c31db2c9e

对比POST中的Signature是否与此值一致

3. 查单接口

URL: /Query?Id=[订单Id]&Signature=[签名]

类型: GET

示例返回

{
    "success": false,
    "message": "订单不存在!"
}
{
    "success": true,
    "message": "订单信息获取成功!",
    "data": {
        "id": "66f9d5a8-d9c7-0224-004f-a16a1c068e08",
        ......
    }
}
字段 类型 说明
此接口返回订单表所有字段
可参考回调数据的字段,也可查阅源代码

查单接口 Signature 计算说明

①示例参数

/Query?Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08

②按照ASCII排序后拼接

Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08

假设异步通知密钥为:666

拼接密钥后 Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08666

③计算MD5

baa261cc6af3f5efbed15e17a285f653

④最终请求参数为

/Query?Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08&Signature=baa261cc6af3f5efbed15e17a285f653