java 非对称加密算法RSA实现详解

 更新时间:2019年07月27日 16:13:03   作者:小破孩123  
这篇文章主要介绍了java 非对称加密算法RSA实现详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下

现在就为大家介绍一种基于因子分解的RSA算法,这种加密算法有两种实现形式:1、公钥加密,私钥解密;2、私钥加密,公钥解密。下面就为大家分析一下实现代码,相对于DH算法,RSA显得有些简单。
初始化密钥:

KeyPairGenerator keyPairGenerator = KeyPairGenerator.getInstance("RSA");
      keyPairGenerator.initialize(512);
      KeyPair keyPair = keyPairGenerator.generateKeyPair();
      RSAPrivateKey rsaprivateKey = (RSAPrivateKey)keyPair.getPrivate();//私有密钥
      RSAPublicKey rsapublicKey = (RSAPublicKey)keyPair.getPublic();//公有密钥
      System.out.println("privateKey : "+Base64.encodeBase64String(rsaprivateKey.getEncoded()));
      System.out.println("publicKey : "+Base64.encodeBase64String(rsapublicKey.getEncoded()));

1、私钥加密,公钥解密:

//私钥加密,公钥解密--加密
      PKCS8EncodedKeySpec pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(rsaprivateKey.getEncoded());
      KeyFactory privateKeyFactory = KeyFactory.getInstance("RSA");
      PrivateKey privateKey = privateKeyFactory.generatePrivate(pkcs8EncodedKeySpec);
      Cipher privateCipher = Cipher.getInstance("RSA");
      privateCipher.init(Cipher.ENCRYPT_MODE, privateKey);
      byte[] result = privateCipher.doFinal(src.getBytes());
      System.out.println("私钥加密,公钥解密--加密:"+Base64.encodeBase64String(result));
      
      //私钥加密,公钥解密--解密
      X509EncodedKeySpec x509EncodedKeySpec = new X509EncodedKeySpec(rsapublicKey.getEncoded());
      KeyFactory publicKeyFactory = KeyFactory.getInstance("RSA");
      PublicKey publicKey = publicKeyFactory.generatePublic(x509EncodedKeySpec);
      Cipher publicCipher = Cipher.getInstance("RSA");
      publicCipher.init(Cipher.DECRYPT_MODE, publicKey);
      result = publicCipher.doFinal(result);
      System.out.println("私钥加密,公钥解密--解密:"+new String(result));

2、公钥加密,私钥解密:

//公钥加密,私钥解密---加密
      x509EncodedKeySpec = new X509EncodedKeySpec(rsapublicKey.getEncoded());
      publicKeyFactory = KeyFactory.getInstance("RSA");
      publicKey = publicKeyFactory.generatePublic(x509EncodedKeySpec);
      publicCipher = Cipher.getInstance("RSA");
      publicCipher.init(Cipher.ENCRYPT_MODE, publicKey);
      result = publicCipher.doFinal(src.getBytes());
      System.out.println("公钥加密,私钥解密---加密:"+Base64.encodeBase64String(result));
      
      //公钥加密,私钥解密---解密
      pkcs8EncodedKeySpec = new PKCS8EncodedKeySpec(rsaprivateKey.getEncoded());
      privateKeyFactory = KeyFactory.getInstance("RSA");
      privateKey = privateKeyFactory.generatePrivate(pkcs8EncodedKeySpec);
      privateCipher = Cipher.getInstance("RSA");
      privateCipher.init(Cipher.DECRYPT_MODE, privateKey);
      result = privateCipher.doFinal(result);
      System.out.println("公钥加密,私钥解密---解密:"+new String(result));

根据输出的结果不难发现,公钥和私钥并不一致,私钥的长度要大于公钥。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot+fileUpload获取文件上传进度

    SpringBoot+fileUpload获取文件上传进度

    这篇文章主要为大家详细介绍了SpringBoot+fileUpload获取文件上传进度,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • SpringBoot实战之SSL配置详解

    SpringBoot实战之SSL配置详解

    今天小编就为大家分享一篇关于SpringBoot实战之SSL配置详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2019-02-02
  • quarzt定时调度任务解析

    quarzt定时调度任务解析

    这篇文章主要介绍了quarzt定时调度任务,具有一定参考价值,需要的朋友可以了解下。
    2017-12-12
  • java基于servlet使用组件smartUpload实现文件上传

    java基于servlet使用组件smartUpload实现文件上传

    这篇文章主要介绍了java基于servlet使用组件smartUpload实现文件上传,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • Springboot 自定义校验代码实例

    Springboot 自定义校验代码实例

    这篇文章主要介绍了Springboot 自定义校验代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2019-11-11
  • Java Filter过滤器的使用教程

    Java Filter过滤器的使用教程

    Filter也称之为过滤器,它是Servlet技术中最实用的技术,Web开发人员通过Filter技术,对web服务器管理的所有web资源:例如Jsp, Servlet, 静态图片文件或静态 html 文件等进行拦截,从而实现一些特殊的功能
    2023-01-01
  • springboot获取URL请求参数的多种方式

    springboot获取URL请求参数的多种方式

    这篇文章主要介绍了springboot获取URL请求参数的多种方式,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2018-01-01
  • Java乱码问题解决方法_动力节点Java学院整理

    Java乱码问题解决方法_动力节点Java学院整理

    开发java应用出现乱码是很常见的,毕竟现在unicode的使用还不是很广泛,下面给大家分享Java乱码问题解决方法,感兴趣的朋友一起看看吧
    2017-07-07
  • 手把手教学Win10同时安装两个版本的JDK并随时切换(JDK8和JDK11)

    手把手教学Win10同时安装两个版本的JDK并随时切换(JDK8和JDK11)

    最近在学习JDK11的一些新特性,但是日常使用基本上都是基于JDK8,因此,需要在win环境下安装多个版本的JDK,下面这篇文章主要给大家介绍了手把手教学Win10同时安装两个版本的JDK(JDK8和JDK11)并随时切换的相关资料,需要的朋友可以参考下
    2023-03-03
  • JSP页面pageEncoding和contentType属性

    JSP页面pageEncoding和contentType属性

    有关于JSP页面中pageEncoding和contentType属性。
    2013-04-04

最新评论