也可参考仓库内现有的独角数卡插件对接
URL: /CreateOrder
类型: POST
Content-Type: application/json
字段 | 类型 | 必填 | 说明 |
---|---|---|---|
OutOrderId | string | 是 | 外部订单号 |
OrderUserKey | string | 是 | 支付用户标识,建议传用户联系方式或用户ID等能识别用户身份的字符串 。使用动态地址时,会根据此字段关联收款地址,传递用户ID等,可以保证系统后续还会为此用户分配此地址。如需要每个订单一个新地址,可向此字段传递外部订单号 。 |
ActualAmount | decimal | 是 | 订单实际支付的法币金额,法币币种依据配置文件中的BaseCurrency 决定,保留两位小数 |
Currency | Enum,支持USDT_TRC20 、TRX 等 |
是 | 加密货币的币种,直接以原样字符串 传递即可 |
PassThroughInfo | 不限长度的任意字符串 | 否 | 在回调通知或订单信息中原样返回 |
NotifyUrl | string? | 否 | 异步通知URL |
RedirectUrl | string? | 否 | 订单支付或过期后跳转的URL |
Signature | string | 是 | 参数签名,参见下方参数签名生成规则 |
{
"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"
}
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
e9765880db6081496456283678e70152
{
"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": "签名验证失败!"
}
如接口返回的状态码不是
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_TRC20 、TRX 等,如配置了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 |
{
"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"
}
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
a8f9d179a8d2798c8b5bb90c31db2c9e
对比POST中的Signature
是否与此值一致
URL: /Query?Id=[订单Id]&Signature=[签名]
类型: GET
示例返回
{
"success": false,
"message": "订单不存在!"
}
{
"success": true,
"message": "订单信息获取成功!",
"data": {
"id": "66f9d5a8-d9c7-0224-004f-a16a1c068e08",
......
}
}
字段 | 类型 | 说明 |
---|---|---|
此接口返回订单表所有字段 | ||
可参考回调数据的字段,也可查阅源代码 |
/Query?Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08
Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08
假设异步通知密钥为:666
拼接密钥后
Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08666
baa261cc6af3f5efbed15e17a285f653
/Query?Id=66f9d5a8-d9c7-0224-004f-a16a1c068e08&Signature=baa261cc6af3f5efbed15e17a285f653