對簽名串做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));


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章