android rsa java_Android XML RSA,ERROR:java.security.InvalidKeyException:传递给RSA的未知密钥类型...

本文讨论了在Android中使用RSA加密时遇到的问题,具体表现为使用XML格式的RSA密钥进行加密时抛出`java.security.InvalidKeyException`。问题可能源于Cipher实例化时的参数设置。代码中使用了`RSA/None/OAEPWithSHA1AndMGF1Padding`和BouncyCastle提供者。作者怀疑问题可能出在这个填充模式,并寻求解决方案。
摘要由CSDN通过智能技术生成

我遇到问题使用RSA加密字符串。 我的RSA是XML格式,看起来像这样:lT8ykfyV0R8o3mJZZezLKTKJpYB90Pzvp0moLzh9CTGfgsxLKYiAl+YGaoRfQ7hVQos5UlLIONHWKPNco9kKcmL6EBJvFc8wqBnhX0p4ML2WSv1yDIRsm9XXra82WHIa3+fxK8bNUJHrucxmpr9pDRPdZGZkz+Q9s94FcOyFKbs=AQAB

我正在尝试使用此类加密字符串:import java.io.BufferedReader;

import java.io.StringReader;

import java.security.KeyPair;

import java.security.PublicKey;

import java.security.Security;

import javax.crypto.Cipher;

import org.bouncycastle.openssl.PEMReader;

import android.util.Base64;

import android.util.Log;

public class RsaEncryption {

private String publicKey;

public RsaEncryption(String publicKey)

{

this.publicKey = publicKey;

}

/*

* Function to encrypt the data.

*

*/

public String encrypt( String data ) throws Exception

{

Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());

Cipher cipher = Cipher.getInstance("RSA/None/OAEPWithSHA1AndMGF1Padding", "BC");

byte[] keyBytes =   Base64.decode( this.publicKey, 0 );

PublicKey publickey       = strToPublicKey(new String(keyBytes));

cipher.init( Cipher.ENCRYPT_MODE , publickey );

// Base 64 encode the encrypted data

byte[] encryptedBytes = Base64.encode( cipher.doFinal(data.getBytes()), 0 );

return new String(encryptedBytes);

}

public static PublicKey strToPublicKey(String s)

{

PublicKey pbKey = null;

try {

BufferedReader br   = new BufferedReader( new StringReader(s) );

PEMReader pr        = new PEMReader(br);

Object obj = pr.readObject();

if( obj instanceof PublicKey )

{

pbKey = (PublicKey) pr.readObject();

}

else if( obj instanceof KeyPair )

{

KeyPair kp = (KeyPair) pr.readObject();

pbKey = kp.getPublic();

}

pr.close();

}

catch( Exception e )

{

Log.d("CIPHER", e.getMessage() );

}

return pbKey;

}

}

你可以看到我正在使用bouncycastle的jar我得到的错误是: java.security.InvalidKeyException:传递给RSA的未知密钥类型

我不确定这一部分Cipher cipher = Cipher.getInstance("RSA/None/OAEPWithSHA1AndMGF1Padding", "BC");

也许这就是问题? 如果是的话,那需要什么呢?

我做了几个小时的研究,仍然没有找到解决方案......

java.security.InvalidKeyException: IOException: DER input, integer tag error是一个Java中的异常类,表示由于输入的DER数据格式有误导致无法解析为有效的密钥。 这个异常通常在使用Java中的加密或签名算法时出现,如RSA、DSA等。它的出现可能是由于以下几种原因引起的: 1. 输入的密钥格式有误:密钥的格式应该符合DER编码规范,如果密钥的编码格式不正确,就会出现这个异常。 2. 密钥生成或提取过程中的错误:可能是在密钥的生成或提取过程中出现了错误,导致生成的或提取的密钥不符合DER编码规范。 3. 密钥的版本或标识错误:有时候,密钥的版本或标识信息与要求的不一致,也会导致这个异常的出现。 要解决这个异常,可以参考以下几个步骤: 1. 确认输入的密钥是否符合DER编码规范:可以使用DER编码格式的解析工具来检查输入的密钥是否正确编码。 2. 检查密钥生成或提取过程中的错误:确认密钥的生成或提取过程中是否有错误发生,例如读取文件时出错、使用了不正确的编码方法等。 3. 确认密钥的版本或标识信息是否正确:查看相关文档或参考示例代码,确认密钥的版本或标识信息是否符合要求。 除了上述解决方法,还可以尝试更新Java运行环境的版本,或使用其他的加密库或算法实现来解决这个问题。如果问题仍然存在,可能需要详细查看代码和错误日志,以便找到更准确的解决方法。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值