[crypto] AEAD是啥
AEAD这个缩写根据不同的语境有两个理解角度:认证加密机制,认证加密方式。
认证加密机制是指:一些用来完成认证加密工作的方法,拆分为认证和加密两部分来做,先加密后加密先认证后认证都无所谓,整个过程或者其目标我们都称之为AEAD。
认证加密方式是指具体的做法:这里我们将狭义的排除掉,认证与加密完全的独立的方式。
下面讨论的,都是排除之后的内容。也就是,当你看见AEAD算法时,一般它仅代表,以下提到的内容。
用一句话解释AEAD就是一种带有认证功能的加密方式。
Authenticated encryption (AE) and authenticated encryption with associated data (AEAD) are forms of encryption which
simultaneously assure the confidentiality and authenticity of data. These attributes are provided under a single, easy to use programming interface.
见wiki:https://en.wikipedia.org/wiki/Authenticated_encryption
常见的可以实现aead的加密模式有这些,wiki里提到的
namely OCB 2.0, Key Wrap, CCM, EAX, Encrypt-then-MAC (EtM), and GCM)
常见里面更常见的,就这两个CCM和GCM
CCM和GCM分别是什么呢?就是分组加密的模式,与CBC是同一个级别的概念。
也就是说,这两个分组加密的模式提供了认证功能。
所以当我们使用AES加密的时候,
AES-CCM和AES-GCM就是aead的算法。AES-CBC就需要另外提供认证算法。
这里有一个rfc,详细讲了CCM和GCM:https://tools.ietf.org/html/rfc5084
标签:
crypto
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 上周热点回顾(3.3-3.9)
2017-03-07 [daily][CentOS][SELinux]用key免登陆不成功,原来是SElinux在搞事情