RSA 秘钥工具类详解

  本文使用PKCS8EncodedKeySpec生成私钥,使用X509EncodedKeySpec生成公钥。此外,使用Base64进行解码和编码.
  完整的文件:Rsa工具类

一、使用 PKCS8EncodedKeySpec 生成私钥的加解密

   1.1 加密
public static String encryptByPrivateKey(String privateKeyText, String text) throws Exception {

        // 解码私钥字符串,得到私钥的 ASN.1 编码格式
        PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyText));

        // 构建 RSA 的秘钥工厂
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");

        // 利用 RSA 秘钥工厂和 PKCS8EncodedKeySpec 生成私钥
        PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec);

        // 创建 RSA 的 Cipher 对象,并提供加密功能
        Cipher cipher = Cipher.getInstance("RSA");

        // Cipher对象需要初始化
        // ENCRYPT_MODE 加密模式
        cipher.init(Cipher.ENCRYPT_MODE, privateKey);

        // 得到需要加密后的二进制数据
        byte[] result = cipher.doFinal(text.getBytes());

        // 返回 Base64 编码后的加密字符串
        return Base64.encodeBase64String(result);
    }

  1.2 解密

public static String decryptByPrivateKey(String privateKeyText, String text) throws Exception {

        // 解码私钥字符串,得到私钥的 ASN.1 编码格式
        PKCS8EncodedKeySpec pkcs8EncodedKeySpec5 = new PKCS8EncodedKeySpec(Base64.decodeBase64(privateKeyText));

        // 构建 RSA 的秘钥工厂
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");

        // 利用 RSA 秘钥工厂和 PKCS8EncodedKeySpec 生成私钥
        PrivateKey privateKey = keyFactory.generatePrivate(pkcs8EncodedKeySpec5);

        // 创建 RSA 的 Cipher 对象,并供解密功能提
        Cipher cipher = Cipher.getInstance("RSA");
        
        // Cipher对象需要初始化
        // DECRYPT_MODE 解密模式
        cipher.init(Cipher.DECRYPT_MODE, privateKey);

        // Base64.decodeBase64(text) 解码密文,从而得到解密后的的二进制数据
        byte[] result = cipher.doFinal(Base64.decodeBase64(text));
        
        // 返回解密后的数据
        return new String(result);
    }

二、使用 X509EncodedKeySpec 生成公钥的加解密

   2.1 加密
    public static String encryptByPublicKey(String publicKeyText, String text) throws Exception {

        // 解码公钥字符串,得到公钥的 ASN.1 编码格式
        X509EncodedKeySpec x509EncodedKeySpec2 = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyText));

        // 构建 RSA 的秘钥工厂
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");

        // 利用 RSA 秘钥工厂和 X509EncodedKeySpec 生成公钥
        PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec2);

        // 创建 RSA 的 Cipher 对象,并提供加密功能
        Cipher cipher = Cipher.getInstance("RSA");

        // Cipher对象需要初始化
        // ENCRYPT_MODE 加密模式
        cipher.init(Cipher.ENCRYPT_MODE, publicKey);

        // 得到需要加密后的二进制数据
        byte[] result = cipher.doFinal(text.getBytes());

        // 返回 Base64 编码后的加密字符串
        return Base64.encodeBase64String(result);
    }

  2.2 解密

public static String decryptByPublicKey(String publicKeyText, String text) throws Exception {

        // 解码公钥字符串,得到公钥的 ASN.1 编码格式
        X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(Base64.decodeBase64(publicKeyText));

        // 构建 RSA 的秘钥工厂
        KeyFactory keyFactory = KeyFactory.getInstance("RSA");

        // 利用 RSA 秘钥工厂和 X509EncodedKeySpec 生成公钥
        PublicKey publicKey = keyFactory.generatePublic(x509EncodedKeySpec);

        // 创建 RSA 的 Cipher 对象,并提供解密功能
        Cipher cipher = Cipher.getInstance("RSA");

        // Cipher对象需要初始化
        // DECRYPT_MODE 解密模式
        cipher.init(Cipher.DECRYPT_MODE, publicKey);

        // Base64.decodeBase64(text) 解码密文,从而得到解密后的的二进制数据
        byte[] result = cipher.doFinal(Base64.decodeBase64(text));

        // 返回解密后的数据
        return new String(result);
    }

三、构建 RSA 秘钥生成器

    public static RsaKeyPair generateKeyPair() throws NoSuchAlgorithmException {

        // 实例化秘钥生成器
        KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");

        // 设置秘钥位数
        keyPairGenerator.initialize(1024);

        // 生成秘钥对
        KeyPair keyPair = keyPairGenerator.generateKeyPair();

        // 公钥对象
        RSAPublicKey rsaPublicKey = (RSAPublicKey) keyPair.getPublic();

        // 私钥对象
        RSAPrivateKey rsaPrivateKey = (RSAPrivateKey) keyPair.getPrivate();

        // 以 Base64 对公钥进行编码
        String publicKeyString = Base64.encodeBase64String(rsaPublicKey.getEncoded());

        // 以 Base64 对私钥进行编码
        String privateKeyString = Base64.encodeBase64String(rsaPrivateKey.getEncoded());
        
        // 返回秘钥对象
        return new RsaKeyPair(publicKeyString, privateKeyString);
    }

四、构建密钥对对象

    public static class RsaKeyPair {
    	// final 修饰
        private final String publicKey;
        private final String privateKey;

        public RsaKeyPair(String publicKey, String privateKey) {
            this.publicKey = publicKey;
            this.privateKey = privateKey;
        }
    }

五、测试

	public static void main(String[] args) throws Exception {
        System.out.println("\n");
        RsaKeyPair keyPair = generateKeyPair();
        System.out.println("公钥:" + keyPair.getPublicKey());
        System.out.println("私钥:" + keyPair.getPrivateKey());
        System.out.println("\n");
        test1(keyPair);
        System.out.println("\n");
        test2(keyPair);
        System.out.println("\n");
    }

    /**
     * 公钥加密私钥解密
     */
    private static void test1(RsaKeyPair keyPair) throws Exception {
        System.out.println("***************** 公钥加密私钥解密开始 *****************");
        String text1 = encryptByPublicKey(keyPair.getPublicKey(), RsaUtils.SRC);
        String text2 = decryptByPrivateKey(keyPair.getPrivateKey(), text1);
        System.out.println("加密前:" + RsaUtils.SRC);
        System.out.println("加密后:" + text1);
        System.out.println("解密后:" + text2);
        if (RsaUtils.SRC.equals(text2)) {
            System.out.println("解密字符串和原始字符串一致,解密成功");
        } else {
            System.out.println("解密字符串和原始字符串不一致,解密失败");
        }
        System.out.println("***************** 公钥加密私钥解密结束 *****************");
    }

    /**
     * 私钥加密公钥解密
     * @throws Exception /
     */
    private static void test2(RsaKeyPair keyPair) throws Exception {
        System.out.println("***************** 私钥加密公钥解密开始 *****************");
        String text1 = encryptByPrivateKey(keyPair.getPrivateKey(), RsaUtils.SRC);
        String text2 = decryptByPublicKey(keyPair.getPublicKey(), text1);
        System.out.println("加密前:" + RsaUtils.SRC);
        System.out.println("加密后:" + text1);
        System.out.println("解密后:" + text2);
        if (RsaUtils.SRC.equals(text2)) {
            System.out.println("解密字符串和原始字符串一致,解密成功");
        } else {
            System.out.println("解密字符串和原始字符串不一致,解密失败");
        }
        System.out.println("***************** 私钥加密公钥解密结束 *****************");
    }

  结果如下所示:
在这里插入图片描述

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值