RSA加密OpenSSLX509CertificateFactory$ParsingException: Error parsing public key报错解决

文章主要讲述了在Java中使用RSA加密时遇到的`OpenSSLX509CertificateFactory$ParsingException:Errorparsingpublickey`错误。通过将公钥转换为Base64编码来解决此问题。修复方法包括使用Base64解码公钥字节,然后生成PublicKey对象进行加密操作。
摘要由CSDN通过智能技术生成

RSA加密OpenSSLX509CertificateFactory$ParsingException: Error parsing public key报错解决

一、代码
private static final String RSA = "RSA";// 非对称加密密钥算法
    private static final String ECB_PKCS1_PADDING = "RSA/ECB/PKCS1Padding";//加密填充方式
    private final static String KEY ="MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAl7CuoFFgrxkQGi/LWV2yIUlLyOT7BaDjT8cJks/tfEUkpSNibvPZ2t0iflBl/i76LmdPwG8Zq23ySmODmgzx8g/Z51Onv6CSQ88jCXdL60UXvFqgcEO34POlyoCyrb1tNXV3ikjFbJVYdpnZ+yNzwCobp8217b6/xAULZgcWu2xlQ6jF1yNV/8YmZvCNfNz6SwOgEaengJzSk1rdfwXrmqzsceZrazSdgdvr69iRPQc69vvlge3tlNOnKo8cmESOnZ4jle5+Xy5/+n7IjEvJlKhOEgpWIF1FfjNDDgHXjl4jng1UoNkgwtxBvarG9YVKMZLdODdfMcwutbB9ayZ+fwIDAQAB"; //公钥
    /**
     * 用公钥对字符串进行加密
     *
     * @param data 原文
     * @return
     */
    @RequiresApi(api = Build.VERSION_CODES.O)
    public static String encryptByPublicKey(byte[] data) throws Exception {
        // 得到公钥
        X509EncodedKeySpec keySpec = new X509EncodedKeySpec(KEY.getBytes());
        KeyFactory kf = KeyFactory.getInstance(RSA);
        PublicKey keyPublic = kf.generatePublic(keySpec);
        // 加密数据
        Cipher cp = Cipher.getInstance(ECB_PKCS1_PADDING);
        cp.init(Cipher.ENCRYPT_MODE, keyPublic);
        return String.valueOf(cp.doFinal(data));
    }

报错如下:

java.security.spec.InvalidKeySpecException: com.android.org.conscrypt.OpenSSLX509CertificateFactory$ParsingException: Error parsing public key
问题解决

将公钥使用base64加密,改为:

@RequiresApi(api = Build.VERSION_CODES.O)
    public static String encryptByPublicKey(byte[] data) throws Exception {
        //获取公钥
        byte[] bytes = Base64.getDecoder().decode(KEY.getBytes());
        KeyFactory kf = KeyFactory.getInstance(RSA);
        PublicKey keyPublic = kf.generatePublic(new X509EncodedKeySpec(bytes));
        // 加密数据
        Cipher cp = Cipher.getInstance(ECB_PKCS1_PADDING);
        cp.init(Cipher.ENCRYPT_MODE, keyPublic);
        return Base64.getEncoder().encodeToString(cp.doFinal(data));
    }
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值