`
wangxuliangboy
  • 浏览: 208026 次
  • 性别: Icon_minigender_1
  • 来自: 上海
文章分类
社区版块
存档分类
最新评论

RSA对称加密报错原因

阅读更多

Exception in thread "main" javax.crypto.BadPaddingException: Data must start with zero
    at sun.security.rsa.RSAPadding.unpadV15(Unknown Source)
    at sun.security.rsa.RSAPadding.unpad(Unknown Source)
    at com.sun.crypto.provider.RSACipher.a(DashoA12275)
    at com.sun.crypto.provider.RSACipher.engineDoFinal(DashoA12275)
    at javax.crypto.Cipher.doFinal(DashoA12275)
    at CipherTest.rsaEncrypt(CipherTest.java:33)
    at CipherTest.main(CipherTest.java:40)

 

RSA是一种对称加密算法,但加密时出现这个错误的原因,是因为使用了私钥进行加密.

正常应该使用公钥进行加密,然后通过私钥进行解密.

代码:

 KeyPair keypair = KeyPairGenerator.getInstance("RSA").generateKeyPair();
        String str = "hello world";
        Cipher cipher = Cipher.getInstance("RSA");

        cipher.init(Cipher.PUBLIC_KEY, keypair.getPublic());
        byte[] buffer = cipher.doFinal(str.getBytes());

        cipher.init(Cipher.PRIVATE_KEY, keypair.getPrivate());
        System.out.println(new String(cipher.doFinal(buffer)));

分享到:
评论
2 楼 ftp2010 2011-04-18  
我用java'的库也验证过,用public key解密private key 加密的数据,也是可以的
我想这个exception还是和padding有关
并不是楼主指出的原因
1 楼 ftp2010 2011-04-18  
这个说法正确吗?
RSA 算法的公钥和私鈅是对称的啊
私鈅加密的公钥能解,公钥加密的私鈅能解
这个我在python程序里也验证过的,java的库有特殊规定吗》?

相关推荐

Global site tag (gtag.js) - Google Analytics