网站首页 > 技术文章 正文
概念
DES(Data Encryption Standard)是数据加密标准的简称,由IBM公司研制。DES是一个分组加密算法,能够支持64比特的明文块加密,其密钥长度为56比特。
DES是世界上应用最广泛的算法。
背后的故事
1997年,RSA实验室发出了破解DES密文的挑战,运用了70000多台计算机,使用暴力攻击程序,大约花费96天的时间找到了正确的DES密钥。
1997年电子前沿基金会花费了250000美元制作的一台超算计算机,在不到3天的时间里就暴力破解了DES密钥。
DES56比特的密钥长度宣布“寿终正寝”。
1999年10月25日采用三重DES作为过渡期间的国家标准,增强了DES的安全性,可以理解成升级版。
技术原理
输入64比特明文数据—>初始转换IP—>在密钥控制下16轮迭代—>交换左右32比特—> 初始逆转换IP-1 –->输出64比特密文数据。
源码实现样例
引用依赖包#:pip install pyDes
脚本如下#:
from pyDes import des,PAD_PKCS5,ECB DES_S_KEY = '12345678' ming = 'this is ming' des_obj = des(DES_S_KEY,ECB,DES_S_KEY,padmode=PAD_PKCS5) s_byte = des_obj.encrypt(ming) # 加密 print(s_byte) c = des_obj.decrypt(s_byte) #解密 print(c) |
结果#:
(env) D:\Codes\python2ctf\Crypto>python Des.py b'\x01\xb2\x07\xc4\x07\xf6V},\x1d\x9cq4\xba4"' b'this is ming' |
3DES加密过程示意
假设:Ek() 和Dk()假设为DES的加密和解密过程,k代码密钥,M代表明文,C代表密文
明文M --> DES Ek1--> DES Dk2 --> DES Ek3 --> 密文C
3DES解密过程示意
Ek() 和Dk()假设为DES的加密和解密过程。
明文M --> DES Dk3 --> DES Ek2 --> DES Dk1 --> 密文C
在线破解
加密解密工具:http://tool.chacuo.net/cryptdes
其中也可以破解部分3DES的加密。
版权说明:请尊重原创版权,版权归本人所有。
- 上一篇: SSL&TLS渗透测试
- 下一篇: Java实现对称加密----AES和DES加密、解密
猜你喜欢
- 2025-01-20 如何给U盘加密?不用装任何工具
- 2025-01-20 软考网络工程师备考-13:网络安全与应用1
- 2025-01-20 等保2.0数据库测评 - Oracle 11g数据库
- 2025-01-20 securecrt中文版
- 2025-01-20 加密算法的分类和简析
- 2025-01-20 VPN协议大揭秘 PPTP与L2TP退场 SSTP与IKEv2成为安全新宠
- 2025-01-20 MiFare RFID的四个系列卡片
- 2025-01-20 C#常用的加密算法:MD5、Base64、SHA1、DES、AES、RSA
- 2025-01-20 常用的加解密技术有哪些?利用Java、Python实现AES、DES、3DES
- 2025-01-20 AES和DES算法的区别,分别有哪些优缺点
你 发表评论:
欢迎- 最近发表
- 标签列表
-
- oraclesql优化 (66)
- 类的加载机制 (75)
- feignclient (62)
- 一致性hash算法 (71)
- dockfile (66)
- 锁机制 (57)
- javaresponse (60)
- 查看hive版本 (59)
- phpworkerman (57)
- spark算子 (58)
- vue双向绑定的原理 (68)
- springbootget请求 (58)
- docker网络三种模式 (67)
- spring控制反转 (71)
- data:image/jpeg (69)
- base64 (69)
- java分页 (64)
- kibanadocker (60)
- qabstracttablemodel (62)
- java生成pdf文件 (69)
- deletelater (62)
- com.aspose.words (58)
- android.mk (62)
- qopengl (73)
- epoch_millis (61)
本文暂时没有评论,来添加一个吧(●'◡'●)