我正在我的 android 应用程序中集成 Payfort 支付网关。我正在使用 FORT SDKv1.2。在创建令牌的帖子网址中,我总是收到错误“签名不匹配”。
谁能告诉我要使用哪个签名?
网址 - https://sbpaymentservices.payfort.com/FortAPI/paymentApi
我正在我的 android 应用程序中集成 Payfort 支付网关。我正在使用 FORT SDKv1.2。在创建令牌的帖子网址中,我总是收到错误“签名不匹配”。
谁能告诉我要使用哪个签名?
网址 - https://sbpaymentservices.payfort.com/FortAPI/paymentApi
让我一步一步地指导你:
注意:以下是商家页面 2.0请求签名生成的示例:
第 1 步:在文件顶部添加这些变量
private final static String KEY_MERCHANT_IDENTIFIER = "merchant_identifier";
private final static String KEY_SERVICE_COMMAND = "service_command";
private final static String KEY_LANGUAGE = "language";
private final static String KEY_ACCESS_CODE = "access_code";
private final static String KEY_MERCHANT_REFERENCE = "merchant_reference";
private final static String MERCHANT_IDENTIFIER = "YOUR_MERCHANT_IDENTIFIER";
private final static String ACCESS_CODE = "YOUR_ACCESS_CODE";
private final static String SHA_TYPE = "SHA-256";
private final static String SHA_REQUEST_PHRASE = "YOUR_SHA_REQUEST_PHRASE ";
private final static String LANGUAGE_TYPE = "en";
确保您使用的是 Payfort 给定的MERCHANT_IDENTIFIER、ACCESS_CODE和SHA_REQUEST_PHRASE。
第 2 步: 创建字符串
String concatenatedString = SHA_REQUEST_PHRASE +
KEY_ACCESS_CODE + "=" + ACCESS_CODE +
KEY_LANGUAGE + "=" + LANGUAGE_TYPE +
KEY_MERCHANT_IDENTIFIER + "=" + MERCHANT_IDENTIFIER +
KEY_MERCHANT_REFERENCE + "=" + YOUR_MERCHANT_REFERENCE +
KEY_SERVICE_COMMAND + "=" + "TOKENIZATION" +
SHA_REQUEST_PHRASE;
此处YOUR_MERCHANT_REFERENCE是您唯一的商家参考。每个请求都应该是唯一的
第 3 步:创建一个函数以从第 2 步中的 concatenatedString 生成 SHA-256 类型签名
private String createSignature(String s) {
try {
// Create MD5 Hash
MessageDigest digest = MessageDigest.getInstance(SHA_TYPE);
digest.update(s.getBytes());
byte messageDigest[] = digest.digest();
return String.format("%0" + (messageDigest.length * 2) + 'x', new BigInteger(1, messageDigest));
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return "";
}
最后 通过在步骤 2 中传递您的 concatenatedString 来调用 createSignature 函数。
String signature = createSignature(concatenatedString);
将 'merchant_reference' 值更改为您以前未使用过的值。它应该是独一无二的。我遇到了同样的麻烦,并且使用它修复了它。
按字母顺序对数组中的密钥进行排序,在密码短语之前和之后添加,然后使用您的算法加密字符串。
之后,您可以在请求中使用它。
我遇到了同样的问题,发现我在生成签名时使用的算法存在问题。所以请在生成签名时检查参数序列。并检查您在帐户中设置的算法并在生成签名时使用相同的算法
在这里您可以找到如何生成签名。
signature mismatch
由于将错误的SHA 请求短语连接到签名的开头和结尾,我遇到了这个错误。
还要确保商家参考是字母数字,如果您想添加特殊字符,您只能添加 . _ -
使用此代码
String concatenatedString = SHA_REQUEST_PHRASE +
KEY_ACCESS_CODE + "=" + ACCESS_CODE +
KEY_DEVICE_ID + "=" + device_id +
KEY_LANGUAGE + "=" + LANGUAGE_TYPE +
KEY_MERCHANT_IDENTIFIER + "=" + MERCHANT_IDENTIFIER +
KEY_SERVICE_COMMAND + "=" + SDK_TOKEN +
SHA_REQUEST_PHRASE;
然后,在下面的方法中传递这个连接的字符串,
private static String getSignatureSHA256(String s) {
try {
// Create MD5 Hash
MessageDigest digest = MessageDigest.getInstance(SHA_TYPE);
digest.update(s.getBytes());
byte messageDigest[] = digest.digest();
return String.format("%0" + (messageDigest.length * 2) + 'x', new BigInteger(1, messageDigest));
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
}
return "";
}
使用以下代码获取签名,
String signature = getSignatureSHA256(concatenatedString);
快乐编码:)