Fiat Currency Payment
# Request URL
- POST https://test2-openapi.91fafafa.com/api/payment/thailand/order/create/v1
# Request parameters
Parameter | Type | Required | Description | Example |
---|---|---|---|---|
appId | string | Y | Merchant AppId | B2iwKFIM4tvo |
merchantId | string | Y | Merchant id | CH10001165 |
mchOrderNo | string | Y | Merchant order number (Length is limited to 32 digits) | 202401221112003 |
paymentMethod | string | Y | Payment Methods ALL-Not specifying a payment method, select it after entering the cashier qrPay-QR Code Payment KBANK-Online Banking Transfer | ALL |
amount | string | Y | Amount | 800 |
payeeAccountInfos | string | N | Payment information JSON string is required when using bank transfer as the payment method. However, it is not required when the paymentMethod is set to ALL or qrPay | {"accountNumber":"88886666"} |
notifyUrl | string | Y | Notification callback URL | https://yourdomain/notifyUrl |
timestamp | long | Y | Submission time (Timestamp: Milliseconds) | 1706000130000 |
sign | string | Y | Signature |
# Example of request message
{
"appId": "B2iwKFIM4tvo",
"merchantId": "CH10001165",
"mchOrderNo": "202401221112003",
"paymentMethod": "ALL",
"amount": "800",
"payeeAccountInfos": "{\"accountNumber\":\"88886666\"}",
"notifyUrl": "https://yourdomain/notifyUrl",
"timestamp": "1706000130000",
"sign": "Q4LSPMuCXvf6Kiox8dlSXucHEWUykXp2iVh4LDokCd4MvYomA5IP5evd3zMQaM/WPW8cByA5EtqqjoU2QWOeAATCm3NE8nTV1MKUduFhKRXfTLvD9i/ZJ/juQB4VjJ0dRPW8rwdB/wrQE0D6hjz4iBj2/K7o9OZZfQvu1YbIICIlF83+7e/qORIdK5IaYrZBCf/avp0x2Qlgk6N3Yc2QpbGkPHTid4nofECQO69Rn8V0T79fNcbzgOEbivusG+T37vjGCBVxDUnq+Zk8cZmTYvu8n0bfqoCc3yaAW3p9bO7CMNe2kXOK1ZZHGl+dLO6mqeG4lB0UHpqS1g6L2rYLCA=="
}
# Response parameters
Parameter | Type | Required | Description | Example |
---|---|---|---|---|
code | String | Y | Response Code 000000 indicates success, others indicate failure. | 000000 |
msg | String | Y | Response Description success: Successful | success |
tradeNo | String | Y | Platform Order Number | 1746094916709126144 |
cashierLink | String | Y | Cashier's Link | |
sign | String | Y | Signature |
# paymentMethod
is set to either KBANK
, the payeeAccountInfos
parameter is described as follows:
参数 | 类型 | 必填 | 描述 | 示例 |
---|---|---|---|---|
accountNumber | String | Y | 用户付款卡号 | 88886666 |
# Successful response message example
- Order successful response message example
{
"code": "000000",
"msg": "success",
"tradeNo": "1749722116079489024",
"cashierLink": "https://c2c-cashier-test.91fafafa.com/#/tradetrade?orderTradeNumber=3a4110a937614aa6bb41554ee146816f", "sign":"ntFjaWy4aM89OOpMiidlgL3AxsF9y3370vUw3ZSEtvhvJeD5ZaucjdFfHW9gPNErYz/+naScvDmZVLggSP24fh/CJ1O1Opz+nJgCqENudZ99JFDa2DMBYvlyjytC1vppEEEHtEqPKz2ilhmOhR49+HwguCfgUaVMigVTT/RKyGd4byQCdj5FWL27mb0GSj+h3Ymmt3fmxfJKs0xx31VNV+3rnRjzT7InIkJ7qMOH+j5mULIcPbSiOZC84UZ9f9Sv5DMkn/LCG82pJo7BTl2YLezYxCSE+2AVXdWSV96lDz3YKkYfYQREw0bFV8xN/pQ5lhvSAqEhcG5ud70KgCBbnA=="
}
- Order failed response message example
{
"msg":"Merchant order number must be unique",
"code":"A0497",
"sign":"visgrw7sbBDqjvGZdmdvOkFM7u11SYvTL2JaN9RaOoDr8/2C2ogmjQjjsLRMVKz2XxGN+I/i2Bovty9Mf5v3K7HYmQqyjb5kpxMjPnDadq+p5+B/gjmw9mk8G7jXHG9LRCcncTmBR0BNq5cgAt9j7JzBmPHC4J7pYdznvZ4L4krOBB5/swliOkgoOcpQfGrCVA3rolz36e6kPF91LnX5Eqg9H3pJFItRBCtpvLZ0eO+wblGy9No43zsdb3LU1DQuMSO1lBL03l5Fxl6C6+OkVtw+CNr9pBfLh5wOsTM7CtT7QA1z4EJqzxR+3kR0gCdwiJ5S++s7zeyw8sSqNrzuKA=="
}
# Code implementation demo
- Code examples are for reference only, please refer to the request parameter description for specific parameters.
package com.cheesepay;
import com.google.gson.Gson;
import com.cheesepay.CheeseTradeRSAUtil;
import okhttp3.*;
import java.lang.reflect.Type;
import java.util.HashMap;
import java.util.Map;
public class PaymentDemo {
// Platform public key
private static final String PLAT_PUBLIC_KEY ="MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEA1dad35S74jfLPbHJh8P0jDHiTvkxwrtITK97ovVu19B24UdiHyHoEZgtNlS6alFQj1ULQ71d6EPh2rWCNkS2b5HGQXwDYBtwvesVQ8h4Sf3eVPTTLGw3BS7Os4vtDEN6BezMdv3sUG2N5i6JF+5H4CQTq3MD2Cx6u/Cv7oFOdFqeDT0AH+TR7uyZxn69OtkJaHHr834EUcdShJKKMQtbC11WCcut7ilDUgdvZnThiVTq7cfl8mcC9FDKcQ9bMWamScWIB5cJQdUW23Kr0c1NvZlpgPS8U5VODM4Uc4muHJPD2cJmquuJ+4AGP36rEk27lUB3h7B6JI1QGiuh1yyPDwIDAQAB";
// Merchant's private key
private static final String MCH_PRIVATE_KEY ="MIIEvAIBADANBgkqhkiG9w0BAQEFAASCBKYwggSiAgEAAoIBAQC/wgJqa2WHUTrJwdrtOig8lwuKPaL462/1rF45p+xi25uoGUEyiOtB0OC6HLePUfkGYzPULPH/O0yF5GmWkhSuz3lKK/XtXSeRdQIwAQ7lYlhfdJjTLVC7mwkDRZeFePwbnAX5pC0h6Yxf0ibjAglkW2d45AscouZt91xIxgf0VLNZ9dHe8R7j8hPKOGpNi+709ThmRZQVHQLN+6w+mrID7JyWBSbbf2bVWc7UBlHCkudwjEiW/r96CefTukb0SigaS0XpqWEKYHeNWS0DP/a5OUDzXMi6fqHEzMPa6uNYbLpOW1rxMhMhU97W8pLYBba0T9BI7F/xusozxVDVeQbDAgMBAAECggEAdZ4EaU3yemuCiZoUNIoFgBSNiX+A5PlUNPZC3U54mbJl6VeEPADre/Uowj82//uhqR9T/QKMdKbkqwONGEQF16t+k9YfBDatPHTuoI8lmeEWn4Ye7vjOmiPgBVe8NqwcxrqOl67x1+kupt955qerJxlBgE8v2aK5gB3HRwPggSYZgSZJ3X2zQMJ+XN4qe49Un+utqFuGtVRwPQvs/Kazp5GL7WlR0OnpQ2KZ+ur9T58VfTKmIeqBckey7nIrb/fdodJ7IqcykWjSLmy8p84W78iiRDfPn81Ujb231EWW+AbuV399aXBZ4oaR4q8wwkhe9xHUADWLvcfCnMrB40LkEQKBgQD2TEeBEB5Gwj/zpriq23xKJyzfo0hOxzGY/Ol2EykGeEYhny/YiTlMYtOMy37RiGKr4lN7G/pKl2fI5kRjgQM1QXgx6dxd11D0rORXj+SAy6+zAq3NVY4c3zDKmrQQ8x3f2QFffo+TmLtw/BH0Frp+a2lzKzIcXtZ4/akJdVIihwKBgQDHT7xvOaNyAPnnYwpROMI9eUVgFc9pMRAmQ18at8ggZ8M+Ww1nhr00loufzkovCb9MvGR4HSedWHfgmtDu1hUFtl7PItNItsB347yWPxR/lVLs44NVXt7jkFisoBoEBXaNVVt6uOSvBiqINmX3gm4FoisI2SRZsH7nMr07OXO85QKBgCkXdN6Nh9+aTP0jla+7yrK8cnolTc0G4rl5iKHQdInFyz2Ux3DDBDJAUrcsxE3FCWFP80mY01tag1A7SrGnNpfOAnWhZMirQbBwn/AT67WpRfkBu2mEmp8qhYNn6B7j0Nol5FrATMf9NViWVZB5skehOAik7klZcULiXy9ayYdFAoGAA+0bLim5gYZpZdh6nIz8ro9UAYeMdWsFAWv0VKdoJtNEclcC1ZY+5elNSNGcfn63qQBRDlisrhnPCrqiAQJwmZM1HOl3tgf7lKEE1wTZF4ZOguIcdTMQOvVd+dCRkqC07CXRToKT5qq9bb98lLqaBjxikqMMZ0PlzBIgzijckc0CgYAH16CziStEZVvKbiR8b0ftF9mf6V8I0KHianMgV8X6Y51aE0Ig1eQhIvqSjqtBac7gEppiu3OQVrp39uLdgyvDSVta1Hq9QYYTDNt8crt69aD/Th1h5esYvApYyZIhHbFDR5meE4Y3nHpfY7J8zhmfyaVW/6cuwPaToTtrEjQmWQ==";
// Payment interface URL
private static final String apiUrl = "https://test2-openapi.91fafafa.com/api/payment/thailand/order/create/v1";
// Callback URL
private static final String cashNotify = "https://yourdomain/notifyUrl";
public static void main(String[] args) throws Exception {
payment();
}
private static String getCurrentTime(){
LocalDateTime now = LocalDateTime.now();
DateTimeFormatter formatter = DateTimeFormatter.ofPattern("yyyyMMddHHmmss");
return now.format(formatter);
}
private static void payment() throws Exception {
Map<String, Object> requestParams = new HashMap<>();
requestParams.put("appId", "B2iwKFIM4tvo");
requestParams.put("merchantId", "CH10001165");
String currentTime = getCurrentTime();
requestParams.put("mchOrderNo", currentTime);
requestParams.put("paymentMethod", "ALL");
requestParams.put("amount", "800");
requestParams.put("payeeAccountInfos", "{\"accountNumber\":\"88886666\"}");
requestParams.put("notifyUrl", cashNotify);
requestParams.put("timestamp", System.currentTimeMillis());
// 私钥加密
String platSign = CheeseTradeRSAUtil.getSign(requestParams, MCH_PRIVATE_KEY);
System.out.println("platSign..."+platSign);
requestParams.put("sign", platSign);
// 接口请求
Gson gson = new Gson();
String requestBody = gson.toJson(requestParams);
System.out.println("Post Json Params:" + requestBody);
// 发送请求并获取响应
OkHttpClient client = new OkHttpClient();
MediaType mediaType = MediaType.parse("application/json; charset=utf-8");
RequestBody body = RequestBody.create(mediaType, requestBody);
Request request = new Request.Builder()
.url(apiUrl)
.post(body)
.addHeader("User-Agent", "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/93.0.4577.63 Safari/537.36")
.build();
Response response = client.newCall(request).execute();
if (!response.isSuccessful()) {
System.out.println("Request failed: " + response.code() + " - " + response.message());
}
String responseBody = response.body().string();
System.out.println("Response: " + responseBody);
Type type = new com.google.gson.reflect.TypeToken<Map<String, Object>>() {}.getType();
Map<String, Object> map = gson.fromJson(responseBody, type);
boolean verifyResult = CheeseTradeRSAUtil.verifySign(map, PLAT_PUBLIC_KEY);
if (verifyResult) {
// ... Signature verification passed, processing normal business logic.
} else {
// ... Signature Verification Error
}
response.close();
}
}