RSA算法和BASE64编码使用实例

编码工具BASE64 maven包

<!-- https://mvnrepository.com/artifact/commons-codec/commons-codec -->
		<dependency>
		    <groupId>commons-codec</groupId>
		    <artifactId>commons-codec</artifactId>
		    <version>1.10</version>
		</dependency>

使用场景

双方通讯,为保证传输内容的安全。传输过程需要是密文。同时要求对方接收到密文后能够解密(可逆)
下面是RSA通讯流程图(网上找的)。
1、用户A和用户B交换公钥
2、用户A发送给用户B的密文是用用户B的公钥加密得到的
3、用户B获取到用户A发过来的密文后,用自己的私钥(私钥B)去解密
4、用户B发送给用户A的密文也是如此。(用A的公钥加密)
在这里插入图片描述

生成密钥对

/**
  * RSA算法定义
  */
 public static final String KEY_ALGORITHM = "RSA";
 /**
  * 生成密钥对
  * 
  * @return 长度为2的String数组,分别为BASE64编码的公钥和密钥
  * @throws Exception
  */
 public static String[] generateKeyPair(int KEY_SIZE) throws Exception {
   
      KeyPairGenerator keyPairGen = KeyPairGenerator.getInstance(KEY_ALGORITHM);
      keyPairGen.initialize(KEY_SIZE);
      KeyPair keyPair = keyPairGen.generateKeyPair();
      String publicKey = BASE64Tools.encrypt(keyPair.getPublic().getEncoded());
      String privateKey = BASE64Tools.encrypt(keyPair.getPrivate().getEncoded());
      return new String[] {
    publicKey, privateKey };
 }
 public static void main(String[] args) throws Exception {
   
       String[] keyPair = generateKeyPair(1024);
       System.out.println("公钥=" + keyPair[0]);
       System.out.println(
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
RSABase64是两种不同的编码和加密算法RSA是一种非对称加密算法,它使用一对密钥,即公钥和私钥。公钥用于加密数据,而私钥用于解密数据。RSA算法广泛应用于数据加密、数字签名和密钥交换等领域。 Base64是一种编码算法,它将二进制数据转换为可打印的ASCII字符。Base64编码常用于在网络传输中传递二进制数据,或者将二进制数据存储在文本文件中。Base64编码不是加密算法,它只是一种数据格式转换的方法。 在Java中,可以使用Apache Commons Codec库来进行Base64编码和解码操作。你可以通过在Maven项目的pom.xml文件中添加以下依赖来引入commons-codec库: ```xml <!-- https://mvnrepository.com/artifact/commons-codec/commons-codec --> <dependency> <groupId>commons-codec</groupId> <artifactId>commons-codec</artifactId> <version>1.10</version> </dependency> ``` 使用Base64编码和解码可以通过commons-codec库中的Base64类来实现。你可以使用Base64类的encodeBase64String方法将二进制数据编码Base64字符串,使用decodeBase64方法将Base64字符串解码为二进制数据。 而RSA算法使用则需要使用Java的加密库,如Java Cryptography Extension (JCE)。你可以使用JCE提供的RSA算法实现类来生成密钥对、加密和解密数据。 总结起来,RSA是一种非对称加密算法,用于数据加密和解密,而Base64是一种编码算法,用于将二进制数据转换为可打印的ASCII字符。在Java中,可以使用Apache Commons Codec库来进行Base64编码和解码操作,使用Java Cryptography Extension (JCE)来实现RSA算法的加密和解密。 #### 引用[.reference_title] - *1* [RSA算法BASE64编码使用实例](https://blog.csdn.net/qq_43396436/article/details/103478582)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值