# OXXO

### 支付流程

<figure><img src="/files/iYjIyNMQcw1mEmjBPucc" alt=""><figcaption></figcaption></figure>

1、用户在商户网站进行下单选择oxxo付款；

&#x20;2、商户向Supefina发起oxxo支付请求；

&#x20;3、Supefina返回oxxo付款码信息。

&#x20;4、商户将该付款码参考展示给用户；

&#x20;5、用户保存付款码信息到oxxo便利店支付；

6、付款成功；

&#x20;7、Supefina通知商户订单成功。

### 请求地址

<table data-full-width="true"><thead><tr><th width="118">环境名称</th><th>URL</th></tr></thead><tbody><tr><td>SandBox </td><td><mark style="color:blue;"><code>POST</code></mark><br>https://api.supefina.tech/api/supefina/transactions/payin</td></tr><tr><td><mark style="color:red;">正式环境</mark> </td><td><mark style="color:red;"><code>POST</code></mark><br><mark style="color:red;">https://api.supefina.net/api/supefina/transactions/payin</mark></td></tr></tbody></table>

### 请求参数

#### 请求头

<table data-full-width="true"><thead><tr><th>Key</th><th>Value</th></tr></thead><tbody><tr><td><code>Content-Type</code></td><td><code>application/json</code></td></tr></tbody></table>

#### 请求体

<table data-full-width="true"><thead><tr><th width="168">变量名</th><th width="97">类型</th><th width="78">必填</th><th width="524">描述</th></tr></thead><tbody><tr><td>countryId</td><td>String</td><td>是</td><td>国家编号<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#afwzp">字典表-国家编号</a><br>墨西哥：<code>MEX</code></td></tr><tr><td>currency</td><td>String</td><td>是</td><td>币种<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#huo-bi-currency">字典表-货币</a><br>墨西哥比索：<code>MXN</code></td></tr><tr><td>orderAmount</td><td>String</td><td>是</td><td>订单金额<br>单位比索，需要分可以传入小数，支持两位小数</td></tr><tr><td>payProduct</td><td>String</td><td>是</td><td><a href="/pages/17IKBEvxR4cpZue8BRdD#mfocd">支付类型</a><br>oxxo：32</td></tr><tr><td>merId</td><td>String</td><td>是</td><td>商户ID<br>商户ID获取路径：Supefina商户后台-商户管理-基本信息-商户ID</td></tr><tr><td>merOrderNo</td><td>String</td><td>是</td><td>商户订单号</td></tr><tr><td>sign</td><td>String</td><td>是</td><td>签名<br><a href="/pages/DR0Ieg3d88mBdWrXD882">具体参照：签名算法</a></td></tr><tr><td>nonceStr</td><td>String</td><td>是</td><td>随机字符串<br>长度不能超过32位</td></tr><tr><td>callbackUrl</td><td>String</td><td>是</td><td><p>回调地址</p><p>详见<a href="/pages/mfMq4AmXGJtMyIPchGsF">通知回调说明</a></p></td></tr></tbody></table>

### 请求示例

{% code fullWidth="true" %}

```json
{
  "callbackUrl": "http://test.com",
  "countryId": "MEX",
  "currency": "MXN",
  "merId": "8102401785904873",
  "merOrderNo": "2026011918295925593025317",
  "nonceStr": "e4658505b611417daa36981ff021506a",
  "orderAmount": 20,
  "payProduct": "32",
  "sign": "1E3685ED6881BA05106C4CFB012955D1"
}
```

{% endcode %}

签名组装字符串

callbackUrl=<http://test.com\\&countryId=MEX\\&currency=MXN\\&merId=8102401785904873\\&merOrderNo=2026011918295925593025317\\&nonceStr=e4658505b611417daa36981ff021506a\\&orderAmount=20\\&payProduct=32\\&key=8102401785904873>

### 响应参数

<table data-full-width="true"><thead><tr><th width="200">变量名</th><th width="220">类型</th><th width="624">描述</th></tr></thead><tbody><tr><td>code</td><td>String</td><td>响应编码<br>具体参照：<a href="/pages/j56ENY9y4TEhx8ssOv8a">响应状态码</a></td></tr><tr><td>data</td><td>Object</td><td>响应数据</td></tr><tr><td>amount</td><td>BigDecimal</td><td>订单金额</td></tr><tr><td>fee</td><td>BigDecimal</td><td>预收手续费</td></tr><tr><td>merCode</td><td>String</td><td>商户ID</td></tr><tr><td>merOrderNo</td><td>String</td><td>商户订单号</td></tr><tr><td>supefinaOrderNo</td><td>String</td><td>supefina订单号</td></tr><tr><td>transactionStatus</td><td>String</td><td>下单状态<br>该笔订单的的发起状态是否成功，与订单真正的交易状态无关。<br><code>00</code>：下单成功<br><code>04</code>：下单失败</td></tr><tr><td>orderExpirationTime</td><td>String</td><td>过期时间</td></tr><tr><td>channelName</td><td>String</td><td>渠道</td></tr><tr><td>identifier</td><td>String</td><td>付款参考，oxxo付款码值</td></tr><tr><td>url</td><td>String</td><td>收银台交易链接地址</td></tr><tr><td>msg</td><td>String</td><td>响应描述</td></tr></tbody></table>

#### 响应示例

{% code fullWidth="true" %}

```json
{
  "code": "200",
  "msg": "success ",
  "data": {
    "merCode": "8102401785904873",
    "merOrderNo": "2026011918295925593025317",
    "supefinaOrderNo": "2026011903010295e3cf5583e7a4e",
    "amount": 20,
    "fee": 0.6,
    "transactionStatus": "00",
    "url": "https://h5.supefina.tech/mex/oxxo?token=lTuw6Sl%2BbO4OK2qpqcBYLQ5V11Yzyani09/b8G2Spcw=",
    "identifier": "8204230000011759",
    "channelName": "oxxo",
    "orderExpirationTime": "2026-01-31T10:30:00.843"
  }
}
```

{% endcode %}

### 回调通知

提交方式：`POST`

<table data-full-width="true"><thead><tr><th width="200">变量名</th><th width="153">类型</th><th width="624">描述</th></tr></thead><tbody><tr><td>amount</td><td>String</td><td>订单金额</td></tr><tr><td>countryId</td><td>String</td><td><a href="/pages/17IKBEvxR4cpZue8BRdD#afwzp">国家编号</a><br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#afwzp">字典表-国家编号</a></td></tr><tr><td>fee</td><td>String</td><td>预收手续费</td></tr><tr><td>identifier</td><td>String</td><td>付款参考，oxxo条形码值</td></tr><tr><td>merId</td><td>String</td><td>商户ID</td></tr><tr><td>merOrderId</td><td>String</td><td>商户订单号</td></tr><tr><td>nonceStr</td><td>String</td><td>随机字符串<br>长度不能超过32位</td></tr><tr><td>realityAmount</td><td>String</td><td>实收金额</td></tr><tr><td>realityFee</td><td>String</td><td>实收手续费</td></tr><tr><td>reference</td><td>String</td><td>付款参考，oxxo付款码值</td></tr><tr><td>sign</td><td>String</td><td>签名</td></tr><tr><td>status</td><td>String</td><td><a href="/pages/17IKBEvxR4cpZue8BRdD#kxzkj">交易状态</a><br>具体参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#kxzkj">字典表——交易订单状态</a></td></tr><tr><td>supefinaOrderId</td><td>String</td><td>supefina订单号</td></tr><tr><td>transactionType</td><td>String</td><td>交易类型<br><code>01</code>：代收<br><code>02</code>：代付</td></tr></tbody></table>

#### 回调通知示例

{% code fullWidth="false" %}

```json
{
	"amount": "20.00",
	"countryId": "MEX",
	"fee": "1.00",
	"merId": "8302109931230575",
	"merOrderId": "2025072919104648604106643",
	"nonceStr": "e2ffce1e-c54b-456d-8f5a-3cadfd",
	"realityAmount": "20",
	"realityFee": "1.00",
	"reference": "CRTPPY8MAQ67WU8AUGWDPL4N25KCTOT",
	"sign": "A89A7822C07E94CA68B814A4A3AC9902",
	"status": "01",
	"successTime": 1753787454313,
	"supefinaOrderId": "202507290301000b99dfd47bbba43",
	"transactionType": "01"
}
```

{% endcode %}

签名组装字符串

amount=20.00\&countryId=MEX\&fee=1.00\&merId=8302109931230575\&merOrderId=2025072919104648604106643\&nonceStr=e2ffce1e-c54b-456d-8f5a-3cadfd\&realityAmount=20\&realityFee=1.00\&reference=CRTPPY8MAQ67WU8AUGWDPL4N25KCTOT\&status=01\&successTime=1753787454313\&supefinaOrderId=202507290301000b99dfd47bbba43\&transactionType=01\&key=10b8a891ff6a479e8135f3367c17e87d

**回调通知响应**

商户成功收到回调后需同步返回指定字符串：SUCCESS 不返回或返回其他内容默认通知失败\
如：

{% code fullWidth="false" %}

```java
public String test(){
	return "SUCCESS";
}
```

{% endcode %}


---

# Agent Instructions: Querying This Documentation

If you need additional information that is not directly available in this page, you can query the documentation dynamically by asking a question.

Perform an HTTP GET request on the current page URL with the `ask` query parameter:

```
GET https://docs.supefina.net/huan-ying-shi-yong-supefina-de-api-wen-dang/dai-shou/mo-xi-ge/oxxo.md?ask=<question>
```

The question should be specific, self-contained, and written in natural language.
The response will contain a direct answer to the question and relevant excerpts and sources from the documentation.

Use this mechanism when the answer is not explicitly present in the current page, you need clarification or additional context, or you want to retrieve related documentation sections.
