发起支付或预授权
适用于线下POS支付场景
该接口用于通过商户的App向 POS支付App发起支付或预授权指令。
商户的App需通过签名打包上传TMS市场。
发起支付:
POS机会预装Switchio Pay 支付App,商户的App需要与Switchio Pay 支付App进行交互,以完成支付或预授权操作。调用方式如下:
URI = "app://switchiopay/api/main/v7/payment"
| 参数 | 类型 | 描述 | 是否必填 |
|---|---|---|---|
| transactionId | String | 交易id | 必填 |
| amount | int | 金额单位分如1.5EUR则为150 | 必填 |
| currencyCode | int | 货币代码ISO4217 如欧元为978 | 必填 |
| invoiceNumber | string | 自定义的id ,20字符以内不重复id | 必填 |
样例代码如下:
/**
* 处理ECR支付 - 按照规范实现
* @param transactionId 交易ID
* @param amount 支付金额(单位分)
* @param invoiceNumber 自定义交易编号
* @param currencyCode ISO 4217货币数字代码(如 978=EUR, 208=DKK)
* @param callback 回调接口
*/
public void processPayment(String transactionId, int amount, String invoiceNumber, String currencyCode, ECRCallback callback) {
this.ecrCallback = callback;
try {
// 构建 ECR v7 URI
JSONObject paymentData = new JSONObject();
paymentData.put("transactionId", transactionId);
paymentData.put("amount", amount);
paymentData.put("currencyCode", Integer.parseInt(currencyCode));
paymentData.put("invoiceNumber", invoiceNumber);
// 使用手动构建URI确保格式正确
String uriString = "app://switchiopay/api/main/v7/payment?data=" +
android.net.Uri.encode(paymentData.toString());
Uri uri = Uri.parse(uriString);
Intent intent = new Intent(ECR_ACTION, uri);
intent.addFlags(Intent.FLAG_ACTIVITY_REORDER_TO_FRONT);
intent.putExtra("data", paymentData.toString());
intent.putExtra("transactionId", transactionId);
intent.putExtra("amount", amount);
intent.putExtra("currencyCode", Integer.parseInt(currencyCode));
intent.putExtra("invoiceNumber", invoiceNumber);
// 启动Activity并等待结果
activity.startActivityForResult(intent, ECR_PAYMENT_REQUEST_CODE);
Log.d(TAG, "ECR支付Intent已发送,等待结果...");
} catch (Exception e) {
Log.e(TAG, "支付处理异常", e);
Log.e(TAG, "异常详情: " + e.getMessage());
if (callback != null) {
callback.onError("Payment processing error: " + e.getMessage());
}
}
Log.d(TAG, "=== processPayment方法执行完成 ===");
}
提交示例:
app://switchiopay/api/main/v7/preauth?data={"transactionId":"88bb2366-716d-11ed-a1eb-0242ac120002","amount": 1200,"currencyCode":978,"invoiceNumber": "123456789012345678"}
返回示例:
{
"aid": "A0000000283101",
"amount": 500,
"cashbackAmount": 1500,
"aosa": "null",
"appCryptogram": "5F52BA71C7B45441",
"appLabel": "Air Bank",
"authCode": "114546",
"availableBalance": "1000",
"brand": "MASTERCARD",
"cardHolderMessage": "Approved",
"cardInputType": "CLESS",
"cid": "80",
"currency": 203,
"cvmTypeList": [
"PIN_ONLINE"
],
"dateTimeServer": "Jul 16, 2025 14:40:50",
"dateTimeTerminal": "Jul 16, 2025 14:39:37",
"driverNumber": "123456",
"emvResponseData": {
"smartCardScheme": "1",
"authorisationResponseCode": "00"
},
"expiration": "****",
"invoiceNumber": "VS353464556789780",
"isReversed": false,
"merchantIdAcquirer": "TNEXGO01",
"merchantIdIssuer": "1357",
"merchantMessage": "Approved",
"monetToken": "MONETTOKEN",
"odometer": 65403,
"pan": "970348******3910",
"par": "PAR",
"panSequenceNumber": "00",
"refundId": "1234567890",
"responseCode": "OK",
"responseMessage": "potvrzeno",
"reversal": false,
"sequenceNumber": "001001614",
"tipAmount": 100,
"terminalIdAcquirer": "M1TNEXGO01",
"terminalIdIssuer": "M1TNEXGO01",
"tokens": [
"fkdfkjbekjrhljb"
],
"transactionId": "48a3ea7d-b82f-4b42-abbb-5043365e4faa",
"transactionType": "SALE_ONLINE",
"vehicleCode": "1A21234",
"licensePlate": "EL100AC",
"authorizationResponseCode": "00"
}
返回结果:
若调用成功,则返回
"responseCode": OK or Approved若调用失败,则返回
"responseCode": 其他值
注意:如需得到用户卡的标识请保存返回值par.