gpt4 book ai didi

java - 解密错误填充错误

转载 作者:行者123 更新时间:2023-12-01 22:26:20 26 4
gpt4 key购买 nike

我正在尝试在两个代理之间发送加密消息。我有一个字符串,其中包含我转换为字节的信息,对其进行加密,然后再次转换为字符串以发送消息。但是,消息已收到,在接收代理处我收到以下异常

javax.crypto.BadPaddingException: Decryption error
at sun.security.rsa.RSAPadding.unpadV15(Unknown Source)
at sun.security.rsa.RSAPadding.unpad(Unknown Source)
at com.sun.crypto.provider.RSACipher.doFinal(RSACipher.java:354)
at com.sun.crypto.provider.RSACipher.engineDoFinal(RSACipher.java:380)
at javax.crypto.Cipher.doFinal(Cipher.java:2121)
at Hi$1.action(Hi.java:72)
at jade.core.behaviours.Behaviour.actionWrapper(Behaviour.java:344)
at jade.core.Agent$ActiveLifeCycle.execute(Agent.java:1532)
at jade.core.Agent.run(Agent.java:1471)
at java.lang.Thread.run(Unknown Source)

我尝试了同一容器中的代理代码,它工作正常,但是,如果它们位于不同的容器上,则不然。

这就是我加密消息的方式:

String msg1="Message from bob 1"; // message
MSGBOB = cipher.doFinal(msg1.getBytes("ISO-8859-1")); // encryption
msg.setContent(new String (MSGBOB,"ISO-8859-1")); // conversion to string

这就是我解密的方法:

mm = msg.getContent().getBytes("ISO-8859-1");// received message 
m = new String(cipher.doFinal(mm),"ISO-8859-1"); // decryption

最佳答案

使用base64编码进行加密输出,不要使用new String(),因为某些字节值将无法正确表示为字符串。因此,当再次反转为字节时,它将不是正确的加密值

这就是我的意思:

String msg1="Message from bob 1"; // message
MSGBOB = cipher.doFinal(msg1.getBytes("ISO-8859-1")); // encryption
msg.setContent(Base64.encode(MSGBOB)); // conversion to string
This is how I decrypt it :

mm = Base64.decode(msg.getContent());// received message
m = new String(cipher.doFinal(mm),"ISO-8859-1"); // decryption

关于java - 解密错误填充错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28712847/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com