C# | 上位机开发新手指南(八)加密算法——AES

简介: AES——这是在加密算法中相当重要的一种加密方式!虽然这个世界上已经存在了非对称加密算法(比如RSA、ECC等),但是在对称加密算法中,AES的地位依然相当重要。与非对称加密算法不同,对称加密算法使用的是相同的密钥对数据进行加密和解密,因此其加密和解密速度更快,而且更加高效。而在对称加密算法中,AES是目前最安全、最可靠的加密算法之一,其加密强度和运行效率都非常高。因此,无论是在个人计算机、移动设备,还是在服务器和云计算等领域,AES都被广泛应用于数据的加密和解密过程中。

在这里插入图片描述

C# | 上位机开发新手指南(八)加密算法——AES

@[toc]

前言

AES——这是在加密算法中相当重要的一种加密方式!

虽然这个世界上已经存在了非对称加密算法(比如RSA、ECC等),但是在对称加密算法中,AES的地位依然相当重要。与非对称加密算法不同,对称加密算法使用的是相同的密钥对数据进行加密和解密,因此其加密和解密速度更快,而且更加高效。而在对称加密算法中,AES是目前最安全、最可靠的加密算法之一,其加密强度和运行效率都非常高。因此,无论是在个人计算机、移动设备,还是在服务器和云计算等领域,AES都被广泛应用于数据的加密和解密过程中。


AES的特性

块加密

AES是一种块加密算法,它将明文分成固定长度的数据块,每个数据块的长度为128位。每个数据块都会被独立加密,因此其安全性更高。块加密算法的优点在于数据加密后的结果更为稳定、安全,加密结果不会因为明文的微小变化而完全改变,从而更好地保护数据的完整性。

分组密码

AES是一种分组密码,它使用相同的密钥对数据进行加密和解密。加密和解密的过程都是在一个固定长度的数据块中完成的,因此其加密和解密速度更快,而且更加高效。分组密码的优点在于其加密和解密速度非常快,且使用的密钥长度较短,更方便使用。

对称加密

AES是一种对称加密算法,也就是说,发送者和接收者都使用同一个密钥来加密和解密数据。这样可以避免在传输过程中被窃听者获取到密钥,从而保证数据的安全性。对称加密的优点是加密速度快,加密的数据经过加密后,没有人能够在不知道密钥的情况下解密它。

强度高

AES使用的密钥长度可以是128位、192位或256位,密钥越长,其加密强度就越高。因此,AES被广泛认为是目前最安全、最可靠的加密算法之一。AES使用的密钥长度越长,破解它的难度就越大,从而保证了数据的安全性。

高效性

AES加密和解密过程的效率都非常高,这得益于其使用的分组密码、块加密算法等特性。因此,AES被广泛应用于个人计算机、移动设备、服务器和云计算等领域。AES加密和解密速度快,可以快速地加密和解密大量的数据,从而提高了数据加密的效率。


AES算法的参数

在AES加密中可以配置的参数包括以下几个:

密钥长度(Key Length)

AES算法支持三种不同的密钥长度:128位192位256位。在选择密钥长度时,需要考虑加密的安全性和性能,一般来说,密钥长度越长,加密的安全性越高,但性能也会受到影响。

加密模式(Encryption Mode)

AES算法支持多种加密模式,包括ECB、CBC、CFB、OFB和CTR等。不同的加密模式具有不同的特点和安全性,选择合适的加密模式可以提高加密的强度和安全性。

ECB模式

ECB模式是最简单的一种加密模式,它将明文分成若干个块,每个块独立加密。这种模式的优点是加密解密速度快,缺点是对于相同的明文块,加密出来的密文块也是相同的,容易受到攻击。

CBC模式

CBC模式是一种常用的加密模式,它将明文分成若干个块,每个块与前一个块的密文异或后再加密。这样,相同的明文块加密后得到的密文块是不同的,增加了安全性。但是,CBC模式加密解密速度较慢,而且不支持并行加密。

CFB模式

CFB模式是一种比较灵活的加密模式,它将明文分成若干个块,每个块通过加密器得到一个密文块,然后将密文块的一部分与明文块异或得到密文。这种模式的优点是支持任意长度的数据流加密,缺点是加密解密速度较慢。

OFB模式

OFB模式是一种类似CFB模式的加密模式,它将明文分成若干个块,每个块通过加密器得到一个密文块,然后将密文块作为加密器的输入,得到下一个密文块。这种模式的优点是支持任意长度的数据流加密,加密解密速度较快,缺点是加密解密过程中不支持错误传播。

CTR模式

CTR模式是一种比较新的加密模式,它将明文分成若干个块,每个块通过加密器得到一个密文块,然后将密文块与明文块异或得到密文。CTR模式的优点是支持并行加密,加密解密速度较快,缺点是密钥只能使用一次。

填充方式(Padding Mode)

在加密算法里,填充方式就是把数据填充到固定长度的块里的一种方式。AES算法支持多种填充方式,包括PKCS#5、PKCS#7、ISO/IEC 7816-4和ANSI X.923等。不同的填充方式具有不同的特点和安全性,选择合适的填充方式可以提高加密的安全性和效率。

PKCS#5和PKCS#7

这两种填充都是往数据末尾补0的。PKCS#5一般用于块长度为8字节的加密,而PKCS#7可以支持块长度为1到255字节的加密。
这两种填充方式嘛,虽然简单好用,但也容易被攻击者攻击呢,因为填充方式都是固定的,没有啥随机性,所以安全性不太高哦。另外,如果数据本来就以0结尾,那填充后可能会和原始数据搞混,解密的时候就会出问题了。

ISO/IEC 7816-4

这种填充是一种比较常用的填充方式,它是基于ASN.1编码的方式进行填充的。这种填充方式比较灵活,填充后的数据长度也是可变的,可以根据需要进行填充,而且填充后的数据和原始数据是可以区分的,解密的时候不会出问题。
不过它是基于ASN.1编码的方式进行填充,所以实现起来可能会比较复杂。

ANSI X.923

该填充方式也是往数据末尾补0的,不过只在最后一个块里添加填充数据。这种填充方式嘛,简单好用,可以避免数据混淆的问题,但是由于只在最后一个块里添加填充数据,所以安全性可能会有点问题。

初始向量(Initialization Vector)

简称IV,初始向量的位数取决于使用的加密算法和加密模式。
ECB模式不需要使用初始向量;CBC模式和CFB模式的初始向量通常为128位;OFB模式和CTR模式的初始向量通常为64位或者128位。

轮数(Number of Rounds)

AES算法使用轮函数对数据进行加密和解密。轮数指的是轮函数需要执行的次数,它与密钥长度和加密模式有关。
一般来说,轮数越多,加密的安全性越高,但性能也会受到影响。

密钥(Key)

AES算法使用相同的密钥对数据进行加密和解密。密钥是一个随机生成的字符串,它的长度与选择的密钥长度相同。选择强度足够高的密钥对于保证加密的安全性至关重要。


对称加密应用场景示例

以下是一个使用对称加密传递消息的场景示例:

sequenceDiagram
participant User1
participant User2
participant ProgramA
participant ProgramB

User1 ->>  ProgramA: 输入明文和密钥
ProgramA ->> ProgramA: 使用密钥加密明文
ProgramA ->> ProgramB: 发送加密后的密文
ProgramB ->> User2: 新消息提示
User2 ->> ProgramB: 输入密钥
ProgramB ->> ProgramB: 使用密钥解密密文
ProgramB ->> User2: 获得明文
  1. User1输入明文和密钥,并将其发送给ProgramA。
  2. ProgramA使用密钥加密明文,并将加密后的密文发送给ProgramB。
  3. ProgramB向User2发送新消息提示,提示其有一条新的加密信息。
  4. User2输入相应的密钥,对密文进行解密。
  5. ProgramB使用密钥解密密文,并将明文发送给User2,User2获得明文。

AES加解密示例

在这里插入图片描述
请参考此文章:https://blog.csdn.net/lgj123xj/article/details/126300322

相关文章
|
5月前
|
XML 测试技术 API
利用C#开发ONVIF客户端和集成RTSP播放功能
利用C#开发ONVIF客户端和集成RTSP播放功能
3183 123
|
人工智能 编解码 算法
DeepSeek加持的通义灵码2.0 AI程序员实战案例:助力嵌入式开发中的算法生成革新
本文介绍了通义灵码2.0 AI程序员在嵌入式开发中的实战应用。通过安装VS Code插件并登录阿里云账号,用户可切换至DeepSeek V3模型,利用其强大的代码生成能力。实战案例中,AI程序员根据自然语言描述快速生成了C语言的base64编解码算法,包括源代码、头文件、测试代码和CMake编译脚本。即使在编译错误和需求迭代的情况下,AI程序员也能迅速分析问题并修复代码,最终成功实现功能。作者认为,通义灵码2.0显著提升了开发效率,打破了编程语言限制,是AI编程从辅助工具向工程级协同开发转变的重要标志,值得开发者广泛使用。
9095 71
DeepSeek加持的通义灵码2.0 AI程序员实战案例:助力嵌入式开发中的算法生成革新
|
物联网 数据处理 C#
C#实现上位机开发,串口通信,读写串口数据并处理16进制数据
C#实现上位机开发,串口通信,读写串口数据并处理16进制数据。在自动化、物联网以及工业控制行业中,上位机开发是一项重要的技能。本教程主要介绍使用C#进行上位机开发,重点在于串口通信和数据处理。
2512 82
|
10月前
|
算法 安全 数据安全/隐私保护
基于AES的遥感图像加密算法matlab仿真
本程序基于MATLAB 2022a实现,采用AES算法对遥感图像进行加密与解密。主要步骤包括:将彩色图像灰度化并重置大小为256×256像素,通过AES的字节替换、行移位、列混合及轮密钥加等操作完成加密,随后进行解密并验证图像质量(如PSNR值)。实验结果展示了原图、加密图和解密图,分析了图像直方图、相关性及熵的变化,确保加密安全性与解密后图像质量。该方法适用于保护遥感图像中的敏感信息,在军事、环境监测等领域具有重要应用价值。
445 35
|
10月前
|
SQL 小程序 API
如何运用C#.NET技术快速开发一套掌上医院系统?
本方案基于C#.NET技术快速构建掌上医院系统,结合模块化开发理念与医院信息化需求。核心功能涵盖用户端的预约挂号、在线问诊、报告查询等,以及管理端的排班管理和数据统计。采用.NET Core Web API与uni-app实现前后端分离,支持跨平台小程序开发。数据库选用SQL Server 2012,并通过读写分离与索引优化提升性能。部署方案包括Windows Server与负载均衡设计,确保高可用性。同时针对API差异、数据库老化及高并发等问题制定应对措施,保障系统稳定运行。推荐使用Postman、Redgate等工具辅助开发,提升效率与质量。
442 0
|
前端开发 JavaScript 安全
C#一分钟浅谈:Blazor WebAssembly 开发
Blazor WebAssembly 是一个客户端框架,允许开发者使用C#和Razor语法构建Web应用。本文介绍了Blazor WebAssembly的基本概念、常见问题及解决方案,包括路由配置、数据绑定、异步操作、状态管理和性能优化等方面的内容,并分享了一些易错点及如何避免的方法。希望这些内容能帮助你在Blazor WebAssembly开发中少走弯路,提高开发效率。
492 51
|
缓存 算法 安全
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
559 12
|
12月前
|
人工智能 编解码 算法
使用 PAI-DSW x Free Prompt Editing图像编辑算法,开发个人AIGC绘图小助理
使用 PAI-DSW x Free Prompt Editing图像编辑算法,开发个人AIGC绘图小助理
416 0
|
机器学习/深度学习 前端开发 算法
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
1057 4
|
机器学习/深度学习 算法 数据挖掘
C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出
本文探讨了C语言在机器学习中的应用及其重要性。C语言以其高效性、灵活性和可移植性,适合开发高性能的机器学习算法,尤其在底层算法实现、嵌入式系统和高性能计算中表现突出。文章还介绍了C语言在知名机器学习库中的作用,以及与Python等语言结合使用的案例,展望了其未来发展的挑战与机遇。
436 1