Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >加密/解密(对比)

加密/解密(对比)

原创
作者头像
一百减一是零
发布于 2024-08-02 01:29:41
发布于 2024-08-02 01:29:41
2340
举报
文章被收录于专栏:加密解密加密解密

对称加密算法

DES

由来: Data Encryption Standard,是一种对称加密算法,由 IBM 在 1975 年开发,1977 年被美国政府采用为标准加密算法。

概念: DES 使用 64 位密钥对数据进行加密,将明文分成 64 位的块,每次进行加密时,将前一次的密文作为下一次的输入进行加密操作。

特点: 速度较慢,密钥长度较短,容易受到暴力破解攻击。

算法原理: DES 采用分组密码的方式进行加密,将明文分成 64 位的块,先进行 IP 置换,然后进行 16 轮迭代加密操作,最后进行 FP 逆置换。

优缺点: 优点是安全性较高,适合用于加密小数据量;缺点是密钥较短,容易受到暴力破解攻击。

应用场景: DES 算法已经被 AES 替代,一般不再使用。

3DES

由来: Triple Data Encryption Algorithm,是 DES 的一种加强版,由 IBM 在 1998 年提出。

概念: 3DES 将 DES 算法进行三次迭代,使用两个密钥进行加密,总密钥长度为 168 位。

特点: 安全性较高,但运算速度较慢。

算法原理: 3DES 采用分组密码的方式进行加密,将明文分成 64 位的块,先进行 IP 置换,然后进行 3 轮迭代加密操作,最后进行 FP 逆置换。

优缺点: 优点是安全性高,可以用于加密大数据量;缺点是运算速度慢,加密效率低。

应用场景: 3DES 可以用于加密银行卡信息、个人身份证信息等敏感数据。

AES

由来: Advanced Encryption Standard,是最常用的对称加密算法,由比利时密码学家 Joan Daemen 和 Vincent Rijmen 在 1998 年提出。

概念: AES 使用 128 位、192 位或 256 位密钥进行加密,将明文分成 128 位的块,每次进行加密时,先进行 AddRoundKey 操作,然后进行 SubBytes、ShiftRows、MixColumns 四个操作,最后进行 AddRoundKey 操作。

特点: 安全性高,运算速度快,可以同时加密大数据量。

算法原理: AES 采用分组密码的方式进行加密,将明文分成 128 位的块,先进行 AddRoundKey 操作,然后进行 10/12/14 轮迭代加密操作,最后进行 AddRoundKey 操作。

优缺点: 优点是安全性高,运算速度快,适合用于加密大数据量;缺点是密钥长度长,可能会对内存占用造成一定压力。

应用场景: AES 可以用于加密云存储、移动设备、网络传输等数据。

非对称加密算法

RSA

由来: RSA 是一种公钥密码算法,由 Ron Rivest、Adi Shamir 和 Leonard Adleman 在 1977 年提出。

概念: RSA 使用一对公钥和私钥进行加密和解密,公钥可以公开,私钥由个人保管,用于解密。

特点: 安全性较高,但加密速度较慢,密钥长度较长。

算法原理: RSA 的公钥和私钥是基于大质数的数学问题,通过找到两个大质数 p 和 q,计算 n=pq 以及 φ(n)=(p-1)(q-1),再找到一个与 φ(n) 互质的整数 e,计算出 d=e^(-1)mod φ(n),e 和 n 组成公钥,d 和 n 组成私钥。

优缺点: 优点是安全性高,解决了密钥分发问题;缺点是加密速度慢,密钥长度长。

应用场景: RSA 可以用于数字签名数据加密身份认证等领域。

ECC

由来: 椭圆曲线密码算法,是一种公钥密码算法,由 Victor S. Miller 和 Neal Koblitz 在 1985 年提出。

概念: ECC 使用一对公钥和私钥进行加密和解密,公钥可以公开,私钥由个人保管,用于解密。

特点: 安全性高,加密速度快,密钥长度短。

算法原理: ECC 通过椭圆曲线来寻找一个点 P,对于一条曲线 y^2=x^3+ax+b,找到满足 y^2=x^3+ax+b(mod p) 的点 P=(x,y),其中 p 是一个质数,P 和一个系数 n 组成私钥,P 和 n*G(G 为曲线的基点)组成公钥。

优缺点: 优点是安全性高,加密速度快,密钥长度短;缺点是实现难度大,需要专业的数学背景。

应用场景: ECC 可以用于移动设备、物联网、数字证书等领域。

对称与非对称的比较

特点

对称加密

非对称加密

密钥长度

短(<256)

长(>1024)

加/解密速度

安全性

密钥管理

容易

困难

适用场景

小数据量

大数据量

注:常见的哈希算法(MD5、SHA-1、SHA-256 等)也常被用于数据加密。技术栈:加密、解密、哈希算法、证书、数字签名等。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
android开发之&数据的加密解密
加密技术是最常用的安全保密手段,利用技术手段把重要的数据变为乱码(加密)传送,到达目的地后再用相同或不同的手段还原(解密)。加密技术包括两个元素:算法和密钥。算法是将普通的信息或者可以理解的信息与一串数字(密钥)结合,产生不可理解的密文的步骤,密钥是用来对数据进行编码和解密的一种算法。在安全保密中,可通过适当的钥加密技术和管理机制来保证网络的信息通信安全。
玖柒的小窝
2021/12/06
1.1K0
常见加密算法解析-2
DES是对称性加密里常见的一种,全程是Data Encryption Standard,即数据加密标准,是一种使用秘钥加密的块算法。秘钥长度是64位(bit), 超过位数秘钥被忽略。所谓对称性加密,加密和解密秘钥相同。对称性加密一般会按照固定长度,把待加密字符串分成块。不足一整块或者刚好最后有特殊填充字符。常见的填充模式有:'pkcs5'、'pkcs7'、'iso10126'、'ansix923'、'zero' 类型,包括DES-ECB、DES-CBC、DES-CTR、DES-OFB、DES-CFB。
用户5521279
2020/05/27
1.3K0
加密算法概述:分类与常见算法
加密算法可以根据不同的标准进行分类,比如根据密钥的使用方式、加密和解密过程是否可逆等。以下是一些主要的分类方式:
公众号:码到三十五
2024/05/24
9670
加密算法概述:分类与常见算法
探秘加密算法
常见的对称加密算法 DES:分组式加密算法,以64位为分组对数据加密,加解密使用同一个算法。 3DES:三重数据加密算法,对每个数据块应用三次DES加密算法。 AES:高级加密标准算法,是美国联邦政府采用的一种区块加密标准,用于替代原先的DES,目前已被广泛应用。 1)AES/DES/3DES算法 AES、DES、3DES 都是对称的块加密算法,加解密的过程是可逆的。 DES加密算法是一种分组密码,以64位为分组对数据加密,它的密钥长度是56位,加密解密用同一算法。 DES加密算法是对密钥进行保密而公开算法(包括加密和解密算法)。这样,只有掌握了和发送方相同密钥的人才能解读由DES加密算法加密的密文数据。因此,破译DES加密算法实际上就是搜索密钥的编码。对于56位长度的密钥来说,如果用穷举法来进行搜索的话,其运算次数为2 ^ 56 次。 2)3DES算法 3DES算法是基于DES 的对称算法,对一块数据用三个不同的密钥进行三次加密,强度更高。 3)AES算法 AES加密算法是密码学中的高级加密标准,该加密算法采用对称分组密码体制,密钥长度的最少支持为128 位、192 位、256 位,分组长度128 位,算法应易于各种硬件和软件实现。这种加密算法是美国联邦政府采用的区块加密标准。 AES 本身就是为了取代DES的,AES具有更好的安全性、效率和灵活性。 对称算法特点 密钥管理:比较难,不适合互联网,一般用于内部系统; 安全性:中; 加密速度:快好几个数量级 (软件加解密速度至少快 100 倍,每秒可以加解密数 M 比特数据),适合大数据量的加解密处理 2. 非对称加密 非对称加密算法介绍 非对称加密算法,又称为公开密钥加密算法。它需要两个密钥,一个称为公开密钥 (public key),即公钥,另一个称为私有密钥 (private key),即私钥。因为加密和解密使用的是两个不同的密钥,所以这种算法称为非对称加密算法。
用户5521279
2020/01/02
1.3K0
周末给女友讲了遍加密算法,没想到...
哈哈哈,其实只是周末看了小舞而已啦,铁铁们没追更的,赶快去补一下这集,特效炸裂。好了,不扯了,进入正题,最近做的项目,涉及到一些加密算法的选择,小羽在这里顺便也给大家做个总结,一起加深对加密的相关认识。
浅羽技术
2020/12/17
5280
周末给女友讲了遍加密算法,没想到...
简单小结密码学入门知识点
  密码,最初的目的是用于对信息加密,计算机领域的密码技术种类繁多。但随着密码学的运用,密码还被用于身份认证、防止否认等功能上。密码是通信双方按约定的法则进行信息特殊变换的一种重要保密手段。依照这些法则,变明文为密文,称为加密变换;变密文为明文,称为脱密变换。密码在早期仅对文字或数码进行加、脱密变换,随着通信技术的发展,对语音、图像、数据等都可实施加、脱密变换。
步履不停凡
2019/08/23
2.2K0
简单小结密码学入门知识点
通信加密算法
加密算法通常分为对称性加密算法和非对称性加密算法。对于对称性加密算法,信息接收双方都需事先知道密匙和加解密算法且其密匙是相同的,之后便是对数据进行加解密了。
全栈程序员站长
2022/09/01
1.8K0
通信加密算法
保护数据隐私的核心技术:加密算法简述
加密解密算法是用来保护数据安全的重要工具。它们可以将明文转换为密文,并在需要时将密文转换回明文。这篇文章将详细介绍三种常用的加密解密算法:AES、RSA和MD5。
曈曈too
2023/02/27
1.2K0
【愚公系列】软考高级-架构设计师 064-信息安全技术
信息安全技术是一种涉及保护计算机系统、网络和数据不受未经授权的访问、使用、泄露或破坏的技术和方法。信息安全技术的主要目标是确保信息的机密性、完整性和可用性,防止信息在传输和存储过程中遭到未经授权的访问或修改。
愚公搬代码
2024/07/08
2320
软考高级架构师:信息加密技术概念和例题
信息加密技术是信息安全中的核心技术之一,它通过数学算法将原始信息转换成无法直接读懂的密文,以保护信息的安全。信息加密技术主要分为对称加密和非对称加密两大类。
明明如月学长
2024/05/24
1310
软考高级架构师:信息加密技术概念和例题
各种加解密算法比較
DES(Data Encryption Standard):数据加密标准,速度较快,适用于加密大量数据的场合。
全栈程序员站长
2022/07/13
7770
Java - 深入理解加密解密和签名算法
Java应用接口安全性问题可能来源于多个方面,包括但不限于数据加密、身份验证、访问控制、输入验证等。下面我会对这些问题进行详细分析,并提供相应的解决方案和最佳实践。
小小工匠
2024/05/25
4150
Java - 深入理解加密解密和签名算法
信息加密
信息加密(Encryption)是将明文信息转换为密文信息,使之在缺少特殊信息时不可读的过程。只有拥有解密方法的对象,经由解密过程,才能将密文还原为正常可读的内容。
真正的飞鱼
2023/02/21
6900
信息加密
IT领域常见的加密算法详细解析
对称加密算法使用同一个密钥进行加密和解密。这类算法的特点是加密解密速度快,适用于大量数据的加密,但由于密钥管理问题,通常只在安全信道内或结合非对称加密算法使用。
用户7353950
2024/11/23
2220
IT领域常见的加密算法详细解析
加解密算法分析与应用场景
在日常开发中,无论是使用何种编程语言,我们都会遇到加解密的需求。例如,为了保护接口数据安全,我们需要对数据进行加密传输;在HTTPS协议中,通过非对称加密传输客户端私钥,然后双方使用该私钥进行对称加密通信;使用MD5算法进行文件一致性校验等。然而,面对众多的加解密方案,我们往往不清楚何时使用哪种方法。本文将为您梳理当前主流的加解密技术,并对算法进行科普性说明,但不涉及具体算法分析。根据日常应用场景,加解密技术大致可分为以下四类:
不惑
2024/05/13
5540
加解密算法分析与应用场景
常用加密算法解析
今天介绍下工作当中常用的加密算法、分类、应用。 1、对称加密算法 所谓对称,就是采用这种加密方法的双方使用方式用同样的密钥进行加密和解密。密钥是控制加密及解密过程的指令。算法是一组规则,规定如何进行加密和解密。 分类 常用的算法有:DES、3DES、AES等。 DES 全称为Data Encryption Standard,即数据加密标准,是一种使用密钥加密的块算法,1977年被美国联邦政府的国家标准局确定为联邦资料处理标准(FIPS),并授权在非密级政府通信中使用,随后该算法在国际上广泛流传开来。 3
Java技术栈
2018/03/29
3.1K0
011各种加密算法比较
算法选择:对称加密AES,非对称加密: ECC,消息摘要: MD5,数字签名:DSA
上善若水.夏
2018/09/28
4.8K0
常用的加密算法DES3、AES & RSA
DES3,通常指的是三重数据加密算法(Triple Data Encryption Algorithm,3DES)或称为Triple DES,是一种对称加密算法。它是基于原有的DES(Data Encryption Standard)算法扩展而来,通过三次DES加密来增强安全性。
BUG弄潮儿
2024/05/11
4840
常用的加密算法DES3、AES & RSA
2018-10-11 对称加密、非对称加密、Hash算法看完这篇文章加解密就别蒙了散列函数 加密算法
http://hongyitong.github.io/2016/07/18/%E5%AF%B9%E7%A7%B0%E5%8A%A0%E5%AF%86%E3%80%81%E9%9D%9E%E5%AF%B9%E7%A7%B0%E5%8A%A0%E5%AF%86%E3%80%81Hash%E7%AE%97%E6%B3%95/
Albert陈凯
2018/10/12
1.4K0
常见加密算法简析
说到加密算法,开发人员基本都不会陌生。我们平常开发中接触形形色色的加密算法,简单来说分为对称加密算法与非对称加密算法以及散列算法。算法的区别在哪呢?我们可以这么来理解三种算法的区别:
创译科技
2019/06/19
1.4K0
常见加密算法简析
相关推荐
android开发之&数据的加密解密
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档