2. 签名验证机制

筛选参数

各接口文档中指定的参数,且参数的值为非空的参数参与签名,参数名区分大小写。

排序

将筛选的参数按照参数名第一个字符的键值ASCII码递增排序(字母升序排序),如果遇到相同字符则按照第二个字符的键值ASCII码递增排序,以此类推。

拼接参数

将排序后的参数与其对应值,组合成 参数名=参数值 的格式,并且把这些参数用 & 字符连接起来,值为空的参数不参与签名,在最后拼接上 &key= 商户密钥,得到待签名的原始字符串。

签名生成sign

签名采用HmacSHA256签名的方式。将加密结果使用16进制编码成string,转化为小写字符串,得到最终的sign。

示例

商户编号:M211105002038019071 商户密钥:5daea29d7969408984117dd853675ba5 假设传送请求参数json如下:

{
	"merchantNo": "M211105002038019071",
	"version": "1.0",
	"nonceStr": "49efa4d0-8ffa-47d0-a487-5a39e37cafc8",
	"merchantOrderId": "20211111160100001",
	"channelCode": "A001",
	"amount":10000,
	"currency": "INR",
	"email": "",
	"userName": "",
	"mobileNo": "15982360145",
	"notifyUrl": "https://www.baidu.com/",
	"expireTime": 60
}

JAVA签名代码示例如下:

PHP签名代码示例如下:

验签网址:

https://tool.oschina.net/encrypt?type=2

Last updated