對簽名串做BASE64編碼和解碼、驗籤,驗籤失敗的原因
阿新 • • 發佈:2018-12-30
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));