RSA+AES混合加密实例


前言

在服务器与终端设备进行HTTP通讯时,常常会被网络抓包、反编译等技术得到HTTP通讯接口地址和参数。为了确保信息的安全,在生产中使用了很多种加密手段。现如今,RSA+AES因加密技术高、安全系数高等优势,成为当今主流手段。2022年,为了提高毕业设计的难度,毫无疑问选择了数据加密(我的毕业设计就是信息管理系统-强烈推荐使用mybatis-plus代码生成器,后端代码就很简单了),在数据加密方案的选择中,经过大量的查询加密技术进行比较,选择了RSA+AES方案。


提示:以下是本篇文章正文内容,下面案例可供参考

一、AES+RSA混合加密是什么?

RSA加密属于非对称加密,理解为由公钥推出私钥,公钥加密,私钥解密,这就是非对称加密。RSA加密最多117个字节,超过117个字节的数据就会报错,所以在RSA+AES混合加密方案中,用RSA的公钥去加密AES的密钥。
AES加密属于对称加密,理解为公钥与私钥可以相互推出,在实际的加密中用AES密钥(AES密钥实际是一个并不是区分开公钥私钥)去进行加解密。AES+RSA混合加密实际的流程是服务端-客户端数据加密传输流程:服务端AES密钥加密传输数据明文,RSA公钥加密AES密钥;客户端解密AES密钥密文,再用AES密钥解密数据密文,其客户端-服务端亦是如此。其流程如下图
在这里插入图片描述
*RSA、AES加密数学原理如果想深入的了解一下建议去B站看up主可厉害的土豆的视频(链接:https://www.bilibili.com/video/BV1YQ4y1a7n1

二、使用步骤

1.引入库

代码如下(示例):

服务端采用SpringBoot
**POM依赖
        <dependency>
            <groupId>org.bouncycastle</groupId>
            <artifactId>bcprov-jdk15on</artifactId>
            <version>1.47</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
        </dependency>
        <dependency>
            <groupId>commons-codec</groupId>
            <artifactId>commons-codec</artifactId>
            <version>1.11</version>
        </dependency>

2.RAS+AES加密工具类

源代码我已经上传到阿里云(服务端链接:https://tanhua-zjd.oss-cn-beijing.aliyuncs.com/serviceDemo.zip ;客户端:https://tanhua-zjd.oss-cn-beijing.aliyuncs.com/clientDemo.zip,点击链接直接下载)。
源代码因为涉及其它利益,所以只保留了加密的模块,客户端只保留了JS加密代码,没有实际样式。

RSA+AES加密方案参考的该作者的RSA+AES混合加密方案:
https://blog.csdn.net/qq_43248623/article/details/108423695


总结

Learning Process:

Step1: 了解RSA+AES的安全性设计和加密逻辑;
Step2: 了解RSA和AES加密原理,建议B站观看可厉害土豆的加密视频(链接在上面);
Step3: 查阅RSA、AES、DES、CES、SSL签证等这几种加密方案之间的区别,以及安全性系数比较;
Step4: 如果可以完成建议拓展一下客户端与服务端做一下请求拦截进行统一加密以及解密。

希望可以给你带来帮助!!!

  • 1
    点赞
  • 21
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 3
    评论
RSA(Rivest-Shamir-Adleman)是一种非对称加密算法,用于加密和解密数据。C#中提供了对RSA算法的支持。下面是一个简单的示例代码,展示如何使用RSA算法进行加密和解密: ```csharp using System; using System.Security.Cryptography; using System.Text; public class RSADemo { public static void Main() { // 创建RSA实例 using (RSA rsa = RSA.Create()) { try { // 生成RSA的公钥和私钥对 RSAParameters publicKey; RSAParameters privateKey; rsa.KeySize = 2048; // 设置密钥长度 // 生成密钥对 publicKey = rsa.ExportParameters(false); privateKey = rsa.ExportParameters(true); // 要加密的数据 string dataToEncrypt = "Hello, RSA!"; // 加密数据 byte[] encryptedData = EncryptData(Encoding.UTF8.GetBytes(dataToEncrypt), publicKey); // 解密数据 byte[] decryptedData = DecryptData(encryptedData, privateKey); // 显示结果 Console.WriteLine("原始数据: {0}", dataToEncrypt); Console.WriteLine("加密后的数据: {0}", Convert.ToBase64String(encryptedData)); Console.WriteLine("解密后的数据: {0}", Encoding.UTF8.GetString(decryptedData)); } catch (CryptographicException e) { Console.WriteLine(e.Message); } } } // 使用RSA算法加密数据 public static byte[] EncryptData(byte[] dataToEncrypt, RSAParameters publicKey) { using (RSA rsa = RSA.Create()) { try { rsa.ImportParameters(publicKey); return rsa.Encrypt(dataToEncrypt, RSAEncryptionPadding.OaepSHA256); } catch (CryptographicException e) { Console.WriteLine(e.Message); return null; } } } // 使用RSA算法解密数据 public static byte[] DecryptData(byte[] dataToDecrypt, RSAParameters privateKey) { using (RSA rsa = RSA.Create()) { try { rsa.ImportParameters(privateKey); return rsa.Decrypt(dataToDecrypt, RSAEncryptionPadding.OaepSHA256); } catch (CryptographicException e) { Console.WriteLine(e.Message); return null; } } } } ``` 这个示例代码中,我们使用`RSA.Create()`创建了一个RSA实例,并设置了密钥长度为2048位。然后,调用`ExportParameters()`方法生成公钥和私钥对。接下来,我们使用公钥加密数据,然后再用私钥解密数据。最后,我们将结果打印到控制台上。 需要注意的是,RSA算法对于较大的数据加密耗时较长,因此通常会使用RSA算法加密对称加密算法(如AES)的密钥,从而提高加密效率。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Humility_D

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值