Example: MIIEpQIBAAKCAQEA...(Base64编码的签名字符串)
加签是开放平台和商户对于交互消息完整性的校验。加签行为主要发生两个部分:
使用商户私钥对请求体进行 SHA256withRSA 签名后,再进行 Base64 编码的结果。
request.body 进行签名(SHA256WithRSA 计算原始数据的SHA-256哈希值。 使用私钥对哈希值进行签名,即使用私钥对哈希值进行RSA加密。此时得到的加密结果就是数字签名。);Signature signature = Signature.getInstance("SHA256withRSA");
signature.initSign(privateKey);
// 计算 SHA256withRSA 签名时,需要以 utf-8 的编码转换 byte 流,否则可能导致含中文参数的签名计算不正确
signature.update(request.body);
byte[] signedHash = signature.sign();String signature = Base64.getEncoder().encodeToString(signedHash);支付查询基础请求对象
交互数据的编码【utf-8】
"utf-8"
机构号
"2022000000008454"
商户号
"2022000000008454"
请求时间(ISO 8601 格式,带时区)
"2025-10-24T15:00:00.500+08:00"
报文签名类型
"RSA"
交易类型
PAY, CREDIT_CARD, 3D_PREAUTH_VOIDS, 3D_PREAUTH_COMPLETION, REFUND, VOIDS, QUERY, TRANSFER, DOWNLOAD, REGISTRATION, FILEUPLOAD, INQUIRYREGISTRATIONSTATUS, AUTHORIZE "PAY"
接口版本,当前版本为【2.0.0】,目前只能传2.0.0,不能不传
"2.0.0"