签名
1、签名
1.1、签名规则
签名使用SHA1WithRSA算法. secretKey作为 SHA1WithRSA 的密钥,param中对应的参数 + timestamp 作为SHA1WithRSA的操作对象,得到的输出即为签名。
第一步,获取body里的请求参数,参数按字母排序之后,组成字符串
“参数按字母排序”的排序方式为,按照字母从小到大排序,从第一个字母开始比较,一样则比较第二个字母,再一样则比较第三个字母,依此类推。
双引号全部去除,无论是字段名,还是字段值的双引号;
中间不能有空格;
如果字段为null,不参与签名
第二步,获取请求头的timestamp的参数,拼接在第一步的结果后面
第三步,使用secretKey 通过SHA1WithRSA 对第二步结果进行签名
1.2、签名示例
参数 | 值 |
---|---|
companyId | 220 |
apiKey | 1710e1f6b4b54c15bea72e8669966591 |
secretKey | MIICeAIBADANBgkqhkiG9w0BAQEFAASCAmIwggJeAgEAAoGBAI5WJjsBgtiuQQZDs5qe8LBDUm2ZSa4gTBJ |
请求参数如下:
{“companyId”:1,”lang”:”zh-CN”,”customerNo”:”86001308”}
计算签名:
第一步,获取body里的请求参数,参数按字母排序之后,组成下面的字符串: {“companyId”:1,”customerNo”:”86001308”,”lang”:”zh-CN”}
第二步,获取请求头的timestamp的参数,拼接在第一步的结果后面,如下: {companyId:1,customerNo:86001308,lang:zh-CN}1650361143685
第三步,使用secretKey 通过SHA1WithRSA 对第二步结果进行签名,结果如下 : Dihl6oOt5UkaHo9sEouquP3EqbukLX2dAOoKTSGicYryTvH1m9r6vtSLHGutZn7u34/06gjhdpbXRFPdjb51GVHvG75qWXZ1P/boL89xtuja6eTEy9q/aS8R270Q1A+m/MOTxdiifCy0IByrSpCs4VJKaj2d8jlJo2GHznsH+q0=
2.附件说明
java 版本 demo.
Last updated