发起支付或预授权


适用于线下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"
}
返回结果:
  1. 若调用成功,则返回"responseCode": OK or Approved

  2. 若调用失败,则返回"responseCode": 其他值

注意:如需得到用户卡的标识请保存返回值par.

results matching ""

    No results matching ""