对签名串做BASE64编码和解码、验签,验签失败的原因

1、首选看 代码片段

String rtnVal = this.getTreeMap(map1); //排序后的字符串
String checkSign = signTime + "|" + rtnVal;
System.out.println("待加签"+checkSign);
//String signature = MyRSASign.addSign(checkSign, "cg.privateKey");//加签字符串
String signature = new MyRSASign().addSign(+signTime + "|" + rtnVal, "cg.privateKey");//加签字符串

这是对加签名字符串做处理的方法

加完之后  signture值是一个值

单独把相同的串拿出来加签   如下

String checkSign ="1522661114358|||||||||U01|rtb1522661114358||||430105198310231028|00||0||||00|00|165986||||||||个人注册||13371797424||||郑容";
String signature = MyRSASign.addSign(checkSign, "cg.privateKey");//加签字符串


两个signture 值不同


真的是入坑了, 真的得采坑踩多了 就知道了


然后排查 分析

最后是 需要对string字符 转utf8       

    sign.initSign(privateKeyLoadedFromFile);
//指定使用从文件中读取的私钥
      byte[] data = vale.getBytes("utf8");//待签名明文数据
      log.info("待签名的明文串: "+new String(data));


你可能感兴趣的:(方法)