# Card

### 支付流程

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

1、用户在商户网站/应用下单，并选择Card支付；

2、商户向Supefina发起Card支付请求；

3、Supefina返回Card支付URL地址；

4、商户将该地址在用户侧打开；

5、用户按照页面提示进行验证和支付；

6、用户支付成功；

7、Supefina将支付成功信息通知商户。

### 请求地址

<table data-full-width="true"><thead><tr><th width="122">环境名称</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="226">变量名</th><th width="138">类型</th><th width="83">必填</th><th width="504">描述</th></tr></thead><tbody><tr><td>countryId</td><td>String</td><td>是</td><td>国家编号<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#afwzp">字典表-国家编号</a><br>秘鲁：<code>PER</code></td></tr><tr><td>currency</td><td>String</td><td>是</td><td>币种<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#huo-bi-currency">字典表-货币</a><br>秘鲁索尔：<code>PEN</code></td></tr><tr><td>orderAmount</td><td>String</td><td>是</td><td>订单金额<br>单位比索，需要分可以传入小数，支持两位小数</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>nonceStr</td><td>String</td><td>是</td><td>随机字符串<br>长度不能超过32位</td></tr><tr><td>payProduct</td><td>String</td><td>是</td><td><a href="/pages/17IKBEvxR4cpZue8BRdD#mfocd">支付类型</a><br>Card：<code>18</code></td></tr><tr><td>checkOut</td><td>Boolean</td><td>是</td><td>收银台<br><code>true</code>：需要收银台<br><code>false</code>：不需要收银台<br>传<code>true</code></td></tr><tr><td>returnUrl</td><td>Boolean</td><td>否</td><td>支付完成返回地址</td></tr><tr><td>callbackUrl</td><td>String</td><td>是</td><td><p>回调地址</p><p>详见<a href="/pages/mfMq4AmXGJtMyIPchGsF">通知回调说明</a></p></td></tr><tr><td>productName</td><td>String</td><td>是</td><td>商品名称<br>最大50个字符</td></tr><tr><td>productQuantity</td><td>Integer</td><td>否</td><td>商品数量<br>范围[0,1000]</td></tr><tr><td>customerEmail</td><td>String</td><td>否</td><td>顾客邮箱<br>3-256个字符<br><strong>电商行业必传</strong></td></tr><tr><td>receiverAddressMain</td><td>String</td><td>否</td><td>收件地址，街道<br>0-50个字符<br><strong>电商行业必传</strong></td></tr><tr><td>receiverAddressExtra</td><td>String</td><td>否</td><td>收件地址，小区，门牌号<br>0-50个字符<br><strong>电商行业必传</strong></td></tr><tr><td>receiverCity</td><td>String</td><td>否</td><td>收件人城市<br>0-50个字符，可包括空格、连字符、撇号、逗号和点<br><strong>电商行业必传</strong></td></tr><tr><td>receiverProvince</td><td>String</td><td>否</td><td>收件人所在省<br>0-40个字符<br>参数：<a href="https://en.wikipedia.org/wiki/ISO_3166-2">https://en.wikipedia.org/wiki/ISO_3166-2</a>  例：NY<br><strong>电商行业必传</strong></td></tr><tr><td>receiverCountry</td><td>String</td><td>否</td><td>收件人国家<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#afwzp">字典表-国家编号</a>  例：BRA<br><strong>电商行业必传</strong></td></tr><tr><td>receiverZipCode</td><td>String</td><td>否</td><td>邮政编码<br>0-12个字母或数字<br><strong>电商行业必传</strong></td></tr><tr><td>receiverPhone</td><td>String</td><td>否</td><td>收件人电话<br>5-20个字符，需添加区号。如：+1 111111111<br><strong>电商行业必传</strong></td></tr><tr><td>alias</td><td>String</td><td>否</td><td>用户名<br>0-60个字符<br><strong>游戏行业必传</strong></td></tr><tr><td>sign</td><td>String</td><td>是</td><td>签名<br><a href="/pages/DR0Ieg3d88mBdWrXD882">具体参照：签名算法</a></td></tr><tr><td>customerName</td><td>String</td><td>是</td><td>用户名字</td></tr><tr><td>lastName</td><td>String</td><td>否</td><td>用户姓</td></tr><tr><td>customerIdentification</td><td>String</td><td>否</td><td>身份证明（如身份证号）</td></tr><tr><td>customerIdentificationType</td><td>String</td><td>否</td><td>身份证明类型（如身份证）<br><a href="/pages/17IKBEvxR4cpZue8BRdD#ke-hu-shi-bie-hao-lei-xing-customeridentificationtype">身份证明类型</a></td></tr><tr><td>description</td><td>String</td><td>是</td><td><p>描述</p><p>长度不超过200字符，不能带特殊符号</p></td></tr></tbody></table>

### 请求示例

{% code fullWidth="true" %}

```json
{
	"callbackUrl": "http://8.130.9.219:8899/api/supefina/transactions/test/zx",
	"checkOut": "true",
	"countryId": "PER",
	"currency": "PEN",
	"customerEmail": "sdfdf@dd.com",
	"customerIdentification": "23443333",
	"customerIdentificationType": "00",
	"customerName": "cName",
	"customerPhone": "+51333333333",
	"description": "test product desc",
	"lastName": "lName",
	"merId": "8302258550224656",
	"merOrderNo": "2025072611383901961800677",
	"nonceStr": "1421558279604dab90e8237b04b73ac5",
	"orderAmount": "200",
	"payProduct": "18",
	"productName": "test product name",
	"productQuantity": 1,
	"receiverAddressExtra": "Apt 2",
	"receiverAddressMain": "Sample street 357",
	"receiverCity": "Receiver City",
	"receiverCountry": "PER",
	"receiverPhone": "+51333333333",
	"receiverProvince": "Example statex",
	"receiverZipCode": "01245",
	"returnUrl": "http://www.bing.com",
	"sign": "61819A906B49A33112A2AC452C20BD39"// 大写
}
```

{% endcode %}

签名组装字符串

callbackUrl=<http://8.130.9.219:8899/api/supefina/transactions/test/zx\\&checkOut=true\\&countryId=PER\\&currency=PEN\\&customerEmail=sdfdf@dd.com\\&customerIdentification=23443333\\&customerIdentificationType=00\\&customerName=cName\\&customerPhone=+51333333333\\&description=test> product desc\&lastName=lName\&merId=8302258550224656\&merOrderNo=2025072611383901961800677\&nonceStr=1421558279604dab90e8237b04b73ac5\&orderAmount=200\&payProduct=18\&productName=test product name\&productQuantity=1\&receiverAddressExtra=Apt 2\&receiverAddressMain=Sample street 357\&receiverCity=Receiver City\&receiverCountry=PER\&receiverPhone=+51333333333\&receiverProvince=Example statex\&receiverZipCode=01245\&returnUrl=<http://www.bing.com\\&key=10c44658d50e4d0da0fe1e5f7c9074a7>

### 响应参数

<table data-full-width="true"><thead><tr><th width="238">变量名</th><th width="208">类型</th><th width="223">描述</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>currency</td><td>String</td><td>币种<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#huo-bi-currency">字典表-货币</a><br>秘鲁索尔：<code>PEN</code></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>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": "8302258550224656",
		"merOrderNo": "2025072611383901961800677",
		"amount": 200,
		"url": "https://h5.supefina.tech/kushki?token=416e29ddd5ed4a04958173b17fc65fe7",
		"currency": "PEN"
	}
}
```

{% endcode %}

### 回调通知

提交方式：`POST`

<table data-full-width="true"><thead><tr><th width="225">变量名</th><th width="175">类型</th><th width="300">描述</th></tr></thead><tbody><tr><td>amount</td><td>String</td><td>订单金额</td></tr><tr><td>countryId</td><td>String</td><td>国家编号<br>参照：<a href="/pages/17IKBEvxR4cpZue8BRdD#afwzp">字典表-国家编号</a><br>秘鲁：PER</td></tr><tr><td>fee</td><td>String</td><td>预收手续费</td></tr><tr><td>identifier</td><td>String</td><td>付款参考<br>Clabe</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>标识符</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>

#### 回调通知示例

```json
{
	"amount": "200.00",
	"countryId": "PER",
	"fee": "3.00",
	"merId": "8302258550224656",
	"merOrderId": "2025072611383901961800677",
	"msg": "交易成功",
	"nonceStr": "498c7ee6-f84d-4091-a942-f48abc",
	"realityAmount": "200",
	"realityFee": "3.00",
	"reference": "CRTEON0JX1FZFYE42SUE3GGV75A1UM7",
	"sign": "F5AECABAD8DD9F2441DEC7D9C5BE231D",// 大写
	"status": "01",
	"successTime": 1753501120476,
	"supefinaOrderId": "2025071948951070859833344",
	"transactionType": "01"
}
```

签名组装字符串

amount=200.00\&countryId=PER\&fee=3.00\&merId=8302258550224656\&merOrderId=2025072611383901961800677\&msg=交易成功\&nonceStr=498c7ee6-f84d-4091-a942-f48abc\&realityAmount=200\&realityFee=3.00\&reference=CRTEON0JX1FZFYE42SUE3GGV75A1UM7\&status=01\&successTime=1753501120476\&supefinaOrderId=2025071948951070859833344\&transactionType=01\&key=10c44658d50e4d0da0fe1e5f7c9074a7

**回调通知响应**

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

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

### 测试数据

测试环境提供了完整的支付功能，但它只是模拟处理，没有实际的银行交易。

下面您将找到一些可以在测试模式（UAT）下使用的测试卡，以确保您的集成准备就绪。将它们与任何CVV一起使用，输入未来的到期日期。

测试环境的订单金额高于1000，将会触发3DS认证模式， 一旦3DS模式出现，输入1234作为验证码。

* 3DS验证通过的交易测试卡号：

  * `4456528080389860`
  * `4456529267234200`
  * `4456529165328302`
  * `4456524869770255`
  * `4456523340069956`

* 3DS验证拒绝的交易测试卡号：

  * `5451951574925480`

* 未经3DS验证拒绝的交易测试卡号：

  * `4349008516656431`

如果测试过程中，遇到了异常状态码，请直接联系Supefina运营人员处理。


---

# 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/bi-lu/card.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.
