blackberry - 在 BlackBerry 上使用 Bouncy CaSTLe 进行 RSA 填充

标签 blackberry encryption java-me rsa bouncycastle

我正在使用 Bouncy CaSTLe 加密字符串以将它们发送到我的 java web 服务,在那里它们被解密,当消息到达服务器时我得到一个 BadPaddingException,任何人都知道如何正确添加在 J2ME 上使用 Bouncy CaSTLe 填充 RSA 密码?

这是客户端的加密代码:

public byte[] Encrypt(byte[] data)
  {
     RSAKeyParameters publicKey = new RSAKeyParameters(false, new BigInteger(_publicKeyModulus), new BigInteger(_publicKeyExponent));
     RSAEngine engine = new RSAEngine();
     engine.init(true, publicKey);

     byte[] output = engine.processBlock(data, 0, data.length);

     return output;
  } 

这就是我在服务器端解密它的方式:

public byte[] Decrypt(byte[] data)
    {
        try {
            Cipher cipher = Cipher.getInstance("RSA");
            cipher.init(Cipher.DECRYPT_MODE, privateKey);
            byte[] cipherData = cipher.doFinal(data);
            return cipherData;
        } catch (NoSuchAlgorithmException ex) {
            Logger.getLogger(EncryptorDecryptor.class.getName()).log(Level.SEVERE, null, ex);
        } catch (NoSuchPaddingException ex) {
            Logger.getLogger(EncryptorDecryptor.class.getName()).log(Level.SEVERE, null, ex);
        } catch(IllegalBlockSizeException ex) {
            Logger.getLogger(EncryptorDecryptor.class.getName()).log(Level.SEVERE, null, ex);
        } catch(InvalidKeyException ex) {
            Logger.getLogger(EncryptorDecryptor.class.getName()).log(Level.SEVERE, null, ex);
        } catch(BadPaddingException ex) {
            Logger.getLogger(EncryptorDecryptor.class.getName()).log(Level.SEVERE, null, ex);
        }

        return null;
    }

最佳答案

而不是使用 RSAEngine 直接使用 PKCS1Encoding类并用

构造它
PKCS1Encoding engine = new PKCS1Encoding(new RSAEngine());

关于blackberry - 在 BlackBerry 上使用 Bouncy CaSTLe 进行 RSA 填充,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5262696/

相关文章:

blackberry - 如何为 Blackberry LabelField 中的文本添加阴影?

css - 我可以针对 Blackberry HTML 输入字段来增加它们的高度吗?

blackberry - GridFieldManager 不会跨越整个屏幕宽度

java - Blowfish CBC算法空间Padding如何实现

java - 如何使用 Array、List、HashMap 或 HashSet - 创建 BitmapFields 的长列表? ( java 、黑莓)

java - 比 Sun WTK 更好的预 validator

iphone - 如何使一个简单的网站在多个移动浏览器上正确呈现?

security - 通过 Internet 将加密文件从客户端安全地发送到服务器的行业标准是什么?

java - 使用快速求幂进行加密/解密的负求幂

java - j2me中无法播放mp3