银联商务天满服务平台
Java PHP Python



import com.chinaums.open.api.OpenApiCache;
import com.chinaums.open.api.OpenApiContext;
import com.chinaums.open.api.constants.ConfigBean;
import com.chinaums.open.api.internal.util.http.HttpTransport;
import java.util.UUID;

public class OpenApiSdkTest {
    public static void main(String[] args) throws Exception{
        String url = "https://api-mop.chinaums.com/v1/netpay/query";
        //开发者ID
        String appId = "平台分配";
        //开发者秘钥
        String appKey = "平台分配";
        //实例化客户端
        ConfigBean configBean = new ConfigBean();
        OpenApiContext context = new OpenApiContext();
        String request = "{\"requestTimestamp\":\"2022-04-19 15:40:03\",
                    \"mid\":\"898201612345678\",
                    \"tid\":\"88880001\",
                    \"instMid\":\"WGDEFAULT\",
                    \"merOrderId\":\"327M202204141724489725391331\",
                    \"msgId\":\"001\",
                    \"srcReserve\":\"保留字段\"}";
        context.setStartTime(System.currentTimeMillis());
        context.setRequestId(UUID.randomUUID().toString().replace("-", ""));
        context.setOpenServUrl(url.split("/v")[0].concat("/"));
        context.setApiServiceUrl(url);
        context.setVersion(url.split("/")[3]);
        context.setAppId(appId);
        context.setAppKey(appKey);
        context.setConfigBean(configBean);
        context.setServiceCode(url.split("/v")[1].substring(1));
        OpenApiCache.getCurrentToken(context);
        System.out.println(HttpTransport.getInstance().doPost(context, request));
    }
}
<?php
require_once "../utils/Log.php";
require_once "../utils/Tools.php";
require_once "../DefaultOpenApiClient.php";
class DataRequest

{
    public $url = "";
    public $serviceCode = "";
    public $apiVersion ="";
    public $needToken = true;
    public $needDataTag = false;
    public $data;

    function __construct($data, $url)
    {
        $this->data = $data;
        $apiVersion = preg_split("/[/]+/s",$url)[2];
        $this->apiVersion = $apiVersion;
        $serviceCode = strstr($url,$apiVersion);
        $this->url = strstr($url,"/".$apiVersion,true);
        $this->serviceCode = preg_replace("/^" . preg_quote($apiVersion, "/") . "/", "", $serviceCode);
    }
}

class DataDemo{
    public function main(){
        $appid = "平台分配";
        $appkey = "平台分配";
        $url = "https://api-mop.chinaums.com/v1/netpay/query";
        $data = json_encode(array("requestTimestamp"=>"2022-04-19 15=>40=>03",
                    "mid"=>"898201612345678",
                    "tid"=>"88880001",
                    "instMid"=>"WGDEFAULT",
                    "merOrderId"=>"327M202204141724489725391331",
                    "msgId"=>"001",
                    "srcReserve"=>"保留字段"));
        $reqiest = new DataRequest($data,$url);
        $client = new DefaultOpenApiClient();
        $content = $client->execute($reqiest,$appid,$appkey);
        $obj = json_decode($content);
        print_r($obj->errCode);
        print_r($obj->errInfo);
    }
}
$p = new DataDemo();
$p->main();
?>
# -*- coding: utf-8 -*-
from webapi.DefaultOpenApiClient import DefaultOpenApiClient

url = "https://api-mop.chinaums.com/v1/netpay/query"

class DataRequest(object):
    def __init__(self, data: dict) -> dict:
        self.data = data
        self.serviceCode = url[len(url.split("/v")[0])+len(url.split("/")[3])+1: len(url)]
        self.apiVersion = url.split("/")[3]
        self.needToken = True
        self.needDataTag = True

appId="平台分配"
appKey="平台分配"
client = DefaultOpenApiClient(appId, appKey)
cls = DataRequest({\"requestTimestamp\":\"2022-04-19 15:40:03\",
                    \"mid\":\"898201612345678\",
                    \"tid\":\"88880001\",
                    \"instMid\":\"WGDEFAULT\",
                    \"merOrderId\":\"327M202204141724489725391331\",
                    \"msgId\":\"001\",
                    \"srcReserve\":\"保留字段\"})
response = client.execute(cls)
print(str(response.get("data")))
print(response.get("errCode"))
print(response.get("errInfo"))
print(response.get("resultCode"))
print(response.get("resultInfo"))

订单交易查询

URL

  • 生产环境: POST https://api-mop.chinaums.com/v1/netpay/query
  • 测试环境: POST https://test-api-open.chinaums.com/v1/netpay/query

描述:钱包支付时,因通讯故障、服务器故障等原因,造成收银机最终没有收到支付结果通知,收银员不确定该笔支付后台处理结果,可以在收银机上发起“查询”交易,查询该笔交易订单在钱包后台的支付结果,并将支付结果返回给收银机。

ContentType:HTTP(S) + JSON

请求头

名称 必填 描述 示例值
Authorization 认证内容(认证参考天满开发者中心->接入指引->平台认证方式:开发者中心 OPEN-BODY-SIG AppId="****",Timestamp="20170606135700",Nonce="99930a147f5353dd8a8f29a5329f37e9",Signature="IPmdGHYCcfN+mto0/02zkwoUF1NT3YqPKaUykMaec1T="

请求参数

名称 类型 必填 最大长度 描述 示例值
requestTimestamp string 报文请求时间 格式yyyy-MM-dd HH:mm:ss 2022-04-19 15:40:03
mid string 15 商户号 898201612345678
tid string 8 终端号 88880001
instMid string 8..32 业务类型 H5DEFAULT WGDEFAULT
merOrderId string 6..32 商户订单号 327M202204141724489725391331
msgId string <=64 消息ID 原样返回 001
srcReserve string <=255 请求系统预留字段 保留字段

响应示例

{
  "errCode":"",
  "errMsg":"",
  "responseTimeStamp":"",
  "mid":"",
  "tid":"",
  "instMid":"",
  "billFunds":"",
  "billFundsDesc":"",
  "payTime":"",
  "couponMerchantContribute":0,
  "couponOtherContribute":0,
  "msgId":"",
  "srcReserve":"",
  "attachedData":"",
  "seqId":"",
  "settleRefId":"",
  "refId":"",
  "status":"",
  "totalAmount":0,
  "merName":"",
  "merOrderId":"",
  "targetOrderId":"",
  "targetSys":"",
  "targetStatus":"",
  "buyerId":"",
  "targetMid":"",
  "bankCardNo":"",
  "bankInfo":"",
  "buyerPayAmount":0,
  "buyerUsername":"",
  "couponAmount":0,
  "invoiceAmount":0,
  "receiptAmount":0,
  "secureStatus":"",
  "completeAmount":0,
  "settleDate":"",
  "subBuyerId":"",
  "activityIds":"",
  "yxlmAmount":0
}

响应参数

名称 类型 必填 最大长度 描述 示例值
errCode string 错误代码
平台错误码
业务错误码
errMsg string 错误信息
responseTimeStamp string 报文应答时间 格式yyyy-MM-dd HH:mm:ss
mid string 15 商户号,原样返回
tid string 8 终端号,原样返回
instMid string 8..32 业务类型,原样返回
billFunds string 支付渠道列表 格式为:方式:金额(单位:分)\
billFundsDesc string 支付渠道描述
payTime string 支付时间 格式yyyy-MM-dd HH:mm:ss
couponMerchantContribute number - 商户出资优惠金额,目前支持微信返回,其他渠道产品规划中
couponOtherContribute number - 其他出资优惠金额,目前支持微信返回,其他渠道产品规划中
msgId string <=64 消息ID,原样返回
srcReserve string <=255 请求系统预留字段
attachedData string 附加数据
seqId string 平台流水号
settleRefId string 清分ID 如果来源方传了bankRefId就等于bankRefId,否则等于seqId
refId string 检索参考号 用在银联体系交易中
status string 交易状态
totalAmount number 支付总金额
merName string 商户名称
merOrderId string 商户订单号
targetOrderId string 目标平台单号
targetSys string 目标平台代码
targetStatus string 目标平台状态
buyerId string 买家ID
targetMid string 支付渠道商户号 各渠道情况不同,酌情转换
bankCardNo string 银行卡号
bankInfo string 银行信息
buyerPayAmount number 买家付款的金额 支付宝会有
buyerUsername string 买家用户名
couponAmount number 渠道优惠金额
invoiceAmount number 交易中可给用户开具发票的金额
receiptAmount number 商户实收金额 支付宝会有
secureStatus string 担保交易状态
completeAmount number 担保完成金额 分
settleDate string 结算日期 格式yyyy-MM-dd
subBuyerId string 子买家ID 如微信的subOpenId
activityIds string 微信活动ID
yxlmAmount number 营销联盟优惠金额 仅享受联盟优惠的订单,查询返回

错误码