代碼如下,byte[] bb = bbb.getBytes(); 這個地方,數組bb與mi內容不一致了,導致解密失敗 很多字節變為了63 請問怎麼解決這個問題?
try {
byte[] tb = ts.getBytes(); //將字符串變為字節數組
byte[] mi = null;
for(int i =0;i<tb.length;i+=64){ //因為不支持117字節以上加密,所以進行分段加密
byte[] doFinal=RSATools.encryptByPublicKey(ArrayUtils.subarray(tb,i,i+64),gy);
mi = ArrayUtils.addAll(mi, doFinal);
}
System.out.println("RSA加密後------------"+new String(mi));
String aaa = encryptBASE64(mi);
System.out.println("\n加密後----" + aaa);
String bbb = new String(decryptBASE64(aaa));
System.out.println("\n"+bbb);
byte[] bb = bbb.getBytes();
byte[] ming = null;
for(int i=0;i<bb.length;i+=128){
byte[] doFinal=RSATools.decryptByPrivateKey(ArrayUtils.subarray(bb, i, i+128), sy);
ming = ArrayUtils.addAll(ming, doFinal);
}
System.out.println("解密後----" + new String(ming));
} catch (Exception e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
字符串變成字符數組,是否為正確。你需要看看加密需要的數據,跟你輸入的字符串類型如何轉換