计算机网络安全 —— 对称加密算法 DES
一、对称加密算法概念
我们通过计算机网络传输数据时,如果无法防止他人窃听, 可以利用密码学技术将发送的数据变换成对任何不知道如何做逆变换人都不可理解的形式, 从而保证了数据的机密性。这种变换被称为加密( encryption),被加密的数据被称为密 文( ciphertext),而加密前的数据被称为明文( plaintext)。 接收方必须能通过某种逆变换将密文重新变换回原来的明文,该逆变换被称为解密( decryption)。加密和解密过程可以 以 一个密钥( key)为参数,并且加密和解密过程可以公开, 而只有密钥需要保密。 即只有知道密钥的人才能解密密文,而任何人,即使知道加密或解密算法也无法解密密文。
采用加密密钥和解密密钥可以相同,也可以不同,取决于采用的是对称密钥密码体制还是公开密钥密码体制。
所谓对称密钥密码体制是一种加密密钥与解密密钥相同的密码体制。在这种加密系统中, 两个参与者共享同一个秘密密钥,如果用一个特定的密钥加密一条消息,也必须要使用相同的密钥来解密该消息。该系统又称为对称密钥系统。
数据加密标准( Data Encryption Standard, DES)是对称密钥密码的典型代表,由IBM公司研制,于1977年被美国定为联邦信息标准 。其加密解密基本流程如下图:

二、.NET 使用 DES 加密
DES使用的密钥为64 位( 实际密钥长度为56 位,有8位用于奇偶校验)。密码的字节长度不能低于64位(8个字节),下面是实现代码:
1 /// <summary>
2 /// DES 加密与解密
3 /// DES加密:https://www.zhihu.com/question/36767829
4 /// 加密基本知识:https://www.biaodianfu.com/des.html
5 /// </summary>
6 public static class DesUtil
7 {
8 public static Encoding Encoding { get; set; }
9
10 #region .ctor
11
12 static DesUtil()
13 {
14 Encoding = Encoding.UTF8;
15 }
16 #endregion
17
18 private const string Key = "https://www.cnblogs.com/dongweian/";
19
20 /// <summary>
21 /// 进行DES加密
22 /// </summary>
23 /// <param name="pToEncrypt">需要加密的字符串</param>
24 /// <param name="sKey">密钥</param>
25 /// <returns></returns>
26 public static string Encrypt(this string pToEncrypt, string sKey = Key)
27 {
28 string base64 = null;
29 using (var des = new DESCryptoServiceProvider())
30 {
31 byte[] keys = Encoding.Default.GetBytes(sKey).Skip(0).Take(8).ToArray();
32 byte[] inputByteArray = Encoding.GetBytes(pToEncrypt);
33 des.Key = keys;
34 des.IV = keys;
35 des.Padding = PaddingMode.PKCS7;
36 des.Mode = CipherMode.CBC;
37 using (var ms = new MemoryStream())
38 {
39 using (var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
40 {
41 cs.Write(inputByteArray, 0, inputByteArray.Length);
42 cs.FlushFinalBlock();
43 }
44 base64 = Convert.ToBase64String(ms.ToArray());
45 }
46 return base64;
47 }
48 }
49
50 /// <summary>
51 /// 进行DES解密
52 /// </summary>
53 /// <param name="pToDecrypt">需要解密的字符串</param>
54 /// <param name="sKey">密钥</param>
55 /// <returns></returns>
56 public static string Decrypt(this string pToDecrypt, string sKey = Key)
57 {
58 string returnValue = null;
59 byte[] inputByteArray = Convert.FromBase64String(pToDecrypt);
60
61 using (var des = new DESCryptoServiceProvider())
62 {
63 byte[] keys = Encoding.GetBytes(sKey).Skip(0).Take(8).ToArray();
64 des.Key = keys;
65 des.IV = keys;
66 des.Padding = PaddingMode.PKCS7;
67 des.Mode = CipherMode.CBC;
68 using (var ms = new MemoryStream())
69 {
70 using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
71 {
72 cs.Write(inputByteArray, 0, inputByteArray.Length);
73 cs.FlushFinalBlock();
74 cs.Close();
75 }
76 returnValue = Encoding.GetString(ms.ToArray());
77 }
78 return returnValue;
79 }
80 }
81 }
二、.NET 使用 3DES 加密
DES使用的密钥为64 位( 实际密钥长度为56 位,有8位用于奇偶校验)。DES 是一 个优秀的密码算法,目前还没有发现比蛮力攻击更好的破解方法。但随着计算机运算速度的快速提高,56位长的密钥已显得太短。56位长的密钥意味着共有256种可能的密钥,也就是说,共约有7. 6 × 1016 种密钥。假设一台计算机1 µ s可执行一次DES加密,同时假定平均只需搜索密钥空间的一半即可找到密钥,那么破译DES要超过1千年。但现在利用并行计算技术已经设计出搜索DES密钥的专用芯片。例如,在1999年有一批在因特网上合作的人借助于一台不到25万美元的专用计算机,在略大于22h的时间就破译了56 位 密钥 的 DES。
为解决DES密钥太短的问题,人们提出了三重DES(Triple DES, 3DES),并在1985年成为美国的一个商用加密标准[ RFC 2420]。3DES在加密时,用三个密钥,执行三次DES算法: 即 E运算 → D运算 → E运算。 解密时,按相反顺序使用这三个密钥,执行D运算 → E运算 → D运算。
3DES目前正在被2001年发布的高级加密标准( Advanced Encryption Standard, AES)所替代。AES能够使用128位、192位和256位长的密钥,用硬件和软件都可以快速实现。它不需要太多内存,因此适用于小型移动设备。美国国家标准与技术研究所NIST估计,如果用1s破解56位DES的计算机来破解一个128位的AES密钥的话,要用大约149万亿年的时间才有可能。

3DES 使用现有的DES算法,并且当三个密钥相同时,效果就和DES一样。这有利于逐步推广使用3DES。也可以仅使用两个密钥,即 K1= K3,相当于密钥长度112位,这对于多数商业应用也已经足够长了。下面代码我们采用192位(24个字节)的3EDS算法:
1 /// <summary>
2 /// 3DES加密与解密
3 /// </summary>
4 public static class TripleDesUtil
5 {
6 private const string Key = "https://www.cnblogs.com/dongweian/";
7 public static Encoding Encoding { get; set; }
8
9 #region .ctor
10
11 static TripleDesUtil()
12 {
13 Encoding = Encoding.UTF8;
14 }
15 #endregion
16
17
18 /// <summary>
19 /// 进行3DES加密
20 /// </summary>
21 /// <param name="pToEncrypt">需要加密的字符串</param>
22 /// <param name="sKey">密钥(用于3DES算法的密钥。密钥大小必须为192位)</param>
23 /// <returns></returns>
24 public static string Encrypt(this string pToEncrypt, string sKey = Key)
25 {
26 string base64 = null;
27 using (var des = new TripleDESCng())
28 {
29 byte[] keys = Encoding.GetBytes(sKey);
30 byte[] inputByteArray = Encoding.GetBytes(pToEncrypt);
31 des.Key = keys.Skip(0).Take(24).ToArray();
32 des.IV = keys.Skip(0).Take(8).ToArray();
33 des.Padding = PaddingMode.PKCS7;
34 des.Mode = CipherMode.CBC;
35 using (var ms = new MemoryStream())
36 {
37 using (var cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
38 {
39 cs.Write(inputByteArray, 0, inputByteArray.Length);
40 cs.FlushFinalBlock();
41 }
42 base64 = Convert.ToBase64String(ms.ToArray());
43 }
44 return base64;
45 }
46 }
47
48 /// <summary>
49 /// 进行3DES解密
50 /// </summary>
51 /// <param name="pToDecrypt">需要解密的字符串</param>
52 /// <param name="sKey">密钥</param>
53 /// <returns></returns>
54 public static string Decrypt(this string pToDecrypt, string sKey = Key)
55 {
56 string returnValue = null;
57 byte[] inputByteArray = Convert.FromBase64String(pToDecrypt);
58
59 using (var des = new TripleDESCng())
60 {
61 byte[] keys = Encoding.GetBytes(sKey);
62 des.Key = keys.Skip(0).Take(24).ToArray();
63 des.IV = keys.Skip(0).Take(8).ToArray();
64 des.Padding = PaddingMode.PKCS7;
65 des.Mode = CipherMode.CBC;
66 using (var ms = new MemoryStream())
67 {
68 using (CryptoStream cs = new CryptoStream(ms, des.CreateDecryptor(), CryptoStreamMode.Write))
69 {
70 cs.Write(inputByteArray, 0, inputByteArray.Length);
71 cs.FlushFinalBlock();
72 cs.Close();
73 }
74 returnValue = Encoding.GetString(ms.ToArray());
75 }
76 return returnValue;
77 }
78 }
79 }
三、测试代码与效果
1 static void Main(string[] args)
2 {
3 string key = "https://www.cnblogs.com/dongweian/";
4 Console.Write($"请输入内容:");
5 string input = Console.ReadLine();
6 var encrypt = TripleDesUtil.Encrypt(input, key);
7 Console.WriteLine($"DES加密后内容:{encrypt}");
8 Console.WriteLine($"DES解密后内容:{TripleDesUtil.Decrypt(encrypt, key)}");
9
10 var encrypt3 = TripleDesUtil.Encrypt(input, key);
11 Console.WriteLine($"3DES加密后内容:{encrypt3}");
12 Console.WriteLine($"3EDS解密后内容:{TripleDesUtil.Decrypt(encrypt3, key)}");
13 Console.ReadKey();
14 }

计算机网络安全 —— 对称加密算法 DES的更多相关文章
- [转] 对称加密算法DES、3DES
转自:http://www.blogjava.net/amigoxie/archive/2014/07/06/415503.html 1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法, ...
- 常用加密算法的Java实现总结(二) ——对称加密算法DES、3DES和AES
1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文(原始数据)和加密密钥(mi yue)一起经过特殊加密算法处理后,使其变成复杂的加密密文发 ...
- 对称加密算法DES,3重DES,TDEA,Blowfish,RC5,IDEA,AES。
对称加密算法:DES,3重DES,TDEA,Blowfish,RC5,IDEA,AES. 1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文 ...
- 对称加密算法DES、3DES和AES 原理总结(转载)
1.对称加密算法 1.1 定义 对称加密算法是应用较早的加密算法,技术成熟.在对称加密算法中,数据发信方将明文(原始数据)和加密密钥(mi yue)一起经过特殊加密算法处理后,使其变成复杂的加密密文发 ...
- 对称加密算法 ~ Des
一.对称加密 (Symmetric Key Encryption) 对称加密是最快速.最简单的一种加密方式,加密(encryption)与解密(decryption)用的是同样的密钥(secret ...
- java-信息安全(二)-对称加密算法DES,3DES,AES,Blowfish,RC2,RC4
概述 信息安全基本概念: DES(Data Encryption Standard,数据加密标准) 3DES(Triple DES,三重数据加密算法(TDEA,Triple Data Encrypti ...
- 第七章 对称加密算法--DES
注意:本节内容主要参考自<Java加密与解密的艺术(第2版)>第7章“初等加密算法--对称加密算法” 7.1.对称加密算法 特点: 加密与解密使用同一个密钥 是使用最广的算法 常见对称加密 ...
- 对称加密算法-DES以及DESede算法
一.简述 对称加密算法就是能将数据加解密.加密的时候用密钥对数据进行加密,解密的时候使用同样的密钥对数据进行解密. DES是美国国家标准研究所提出的算法.因为加解密的数据安全性和密钥长度成正比.des ...
- 计算机网络安全 —— 非对称加密算法 RSA 和数字签名(二)
一.非对称加密算法基本概念 在对称密钥系统中,两个参与者要共享同一个秘密密钥.但怎样才能做到这一点呢?一种是事先约定,另一种是用信使来传送.在高度自动化的大型计算机网络中,用信使来传送密钥显然是不合适 ...
随机推荐
- 微服务痛点-基于Dubbo + Seata的分布式事务(AT)模式
前言 Seata 是一款开源的分布式事务解决方案,致力于提供高性能和简单易用的分布式事务服务.Seata 将为用户提供了 AT.TCC.SAGA 和 XA 事务模式,为用户打造一站式的分布式解决方案. ...
- DateUtils 时间工具类
首先,定义`时间枚举值` public enum TimeEnum { /** * 时间格式 */ YYYY_MM_DD("yyyy-MM-dd"), YYYY_MM_DD_HH_ ...
- 容器编排系统K8s之Volume的基础使用
前文我们聊到了k8s上的ingress资源相关话题,回顾请参考:https://www.cnblogs.com/qiuhom-1874/p/14167581.html:今天们来聊一下k8s上volum ...
- Core3.0中Swagger使用JWT
前言 学习ASP.NETCore,原链接 https://www.cnblogs.com/laozhang-is-phi/p/9511869.html 原教程是Core2.2,后期也升级到了Core3 ...
- root密码忘记了,怎么办?
root是管理员使用的超级用户,如果密码忘记了,可以使用以下两种方法修改. 方法一: 进入单用户模式下进行密码修改 步骤1:重启系统,在系统进入3秒启动阶段,快速点击键盘上任意键可以取消默认进入系统状 ...
- 如何写出安全的、基本功能完善的Bash脚本
每个人或多或少总会碰到要使用并且自己完成编写一个最基础的Bash脚本的情况.真实情况是,没有人会说"哇哦,我喜欢写这些脚本".所以这也是为什么很少有人在写的时候专注在这些脚本上. ...
- Linux嵌入式学习-远程过程调用-Binder系统
Binder系统的C程序使用示例IPC : Inter-Process Communication, 进程间通信RPC : Remote Procedure Call, 远程过程调用 这里我们直接只用 ...
- jsonp详解及跨域请求
什么是JSONP? JSON是一种轻量级的数据传输格式语言,被广泛应用于当前Web应用中.JSON格式数据的编码和解析基本在所有主流语言中都被实现,所以现在大部分前后端分离的架构都以JSON格式进行数 ...
- 伪静态 RewriteRule-htaccess
伪静态实际上是利用PHP把当前地址解析成另一种方法来访问网站,要学伪静态规则的写法,要懂一点正则 一.正则表达式教程 有一个经典的教程:正则表达式30分钟入门教程 常用正则如下: . 换行符以外的所有 ...
- 网络爬虫第一步:通用代码框架(python版)
import requests def getHTMLText(url): try: r=requests.get(url,timeout=30) r.rais ...