Rsa读取pem公钥和私钥

本文介绍如何从PEM格式文件中提取RSA公钥和私钥,并将其转换为可使用的公钥和私钥对象。包括删除PEM文件中的BEGIN和END标记,使用Java读取并解析字符串,以及通过特定的Java代码生成公钥和私钥。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.把pem文件用text打开,把开头和结尾的begin和end内容删去,只留下字符串内容;
2.用流读取文件中的字符串;
3.用以下代码生成公钥和私钥对象;

	public static PublicKey string2PublicKey(String pubStr) throws Exception{
		byte[] keyBytes = base642Byte(pubStr);
		X509EncodedKeySpec keySpec = new X509EncodedKeySpec(keyBytes);
		KeyFactory keyFactory = KeyFactory.getInstance("RSA");
		PublicKey publicKey = keyFactory.generatePublic(keySpec);
		return publicKey;
	}
	
	//将Base64编码后的私钥转换成PrivateKey对象
	public static PrivateKey string2PrivateKey(String priStr) throws Exception{
		byte[] keyBytes = base642Byte(priStr);
		PKCS8EncodedKeySpec keySpec = new PKCS8EncodedKeySpec(keyBytes);
		KeyFactory keyFactory = KeyFactory.getInstance("RSA");
		PrivateKey privateKey = keyFactory.generatePrivate(keySpec);
		return privateKey;
	}

备注:
读取私钥前要加上:
java.security.Security.addProvider(new org.bouncycastle.jce.provider.BouncyCastleProvider());
运行服务,不然运行会出现algid parse error, not a sequence错误。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值