DES加密算法以及代码实现(python)
off999 2024-09-23 11:34 34 浏览 0 评论
DES 对称加密算法
DES(Data Encryption Standard)是一种对称加密算法,广泛用于保护敏感数据的安全性。它由IBM公司研发于上世纪70年代中期,并在1977年被美国国家标准技术研究院(NIST)正式采纳为标准。
DES加密算法基于对称密钥体制,意味着加密和解密过程使用相同的密钥。密钥长度为56位,分为8个字节。算法将明文数据以64位的块进行处理,并通过一系列的替代、置换和混合运算来循环加密数据多轮(通常是16轮),最终生成密文。
DES算法中的核心部分是轮函数,它包括如下步骤:
- 初始置换(IP):对输入数据进行置换,重排数据的顺序。
- 轮运算(Feistel Network):将输入数据分为左右两半,经过一系列相同的运算并结合密钥进行处理。
- 逆初始置换(IP-1):对经过轮运算后的数据再进行置换,生成最终的加密结果。
DES 对称加密算法优缺点
DES(Data Encryption Standard)是一种对称加密算法,它具有以下优点和缺点:
优点:
- 安全性较高:DES算法采用对称密钥体制,只有持有正确密钥的人可以解密数据,有效保护数据的机密性。
- 快速性能:DES算法的加解密过程相对较快,适用于对大量数据进行加密和解密的场景。
- 算法公开:DES算法的设计和实现是公开的,用户可以更好地理解其工作原理,对其进行审计和改进。
缺点:
- 密钥长度过短:DES算法的密钥长度为56位,相对较短,容易受到穷举攻击(Brute-force Attack)的威胁。现代计算机的计算能力迅速增强,可以通过穷举尝试所有可能的密钥来破解DES加密。
- 安全性受限:由于DES算法设计于上世纪70年代,其设计已经过时,不再足以应对当前的安全需求。DES算法已经遭到多种攻击手段的突破,如差分攻击、线性攻击等。
- 无法适应长密钥长度:DES算法所能使用的密钥长度固定为56位,在现代加密需求中,这样的密钥长度已经不够安全。
鉴于DES算法的安全性问题和技术进展,现在更常见的是采用AES(Advanced Encryption Standard)等更安全的对称加密算法来替代DES。AES具有更长的密钥长度、更高的安全性和更好的性能,被广泛应用于数据加密和保护。
代码实现(python)
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import binascii
import pyDes
"""
Des 加解密
"""
class Des:
def __init__(self, key):
"""
初始化
:param key: 8位key
"""
self.key = key.encode("utf8")
def encrypt(self, s) -> bytes:
"""
加密
:param s: 原始字符串
:return: 16进制加密后字符串
"""
secret_key = self.key
k = pyDes.des(secret_key, pyDes.triple_des, pad=None, padmode=pyDes.PAD_PKCS5)
en = k.encrypt(s.encode("utf8"), padmode=pyDes.PAD_PKCS5)
# 二进制数据的16进制的表现形式
return binascii.b2a_hex(en)
def descrypt(self, s) -> bytes:
"""
解密
:param s: 16进制加密后的字符串
:return: 解密后的字符串
"""
secret_key = self.key
k = pyDes.des(secret_key, pyDes.triple_des, pad=None, padmode=pyDes.PAD_PKCS5)
return k.decrypt(binascii.a2b_hex(s), padmode=pyDes.PAD_PKCS5)
# 8个字节长度秘钥
des = Des('zX9]qS5)')
# 原值
raw_str = "白日依山尽" # 待加密的数据
print("原始值:", raw_str)
encrypt_str = des.encrypt(raw_str)
print("加密值:", encrypt_str.decode())
print("解密值:", des.descrypt(encrypt_str).decode())
相关推荐
- PYTHON-简易计算器的元素介绍
-
[烟花]了解模板代码的组成importPySimpleGUIassg#1)导入库layout=[[],[],[]]#2)定义布局,确定行数window=sg.Window(...
- 如何使用Python编写一个简单的计算器程序
-
Python是一种简单易学的编程语言,非常适合初学者入门。本文将教您如何使用Python编写一个简单易用的计算器程序,帮助您快速进行基本的数学运算。无需任何高深的数学知识,只需跟随本文的步骤,即可轻松...
- 用Python打造一个简洁美观的桌面计算器
-
最近在学习PythonGUI编程,顺手用Tkinter实现了一个简易桌面计算器,功能虽然不复杂,但非常适合新手练手。如果你正在学习Python,不妨一起来看看这个项目吧!项目背景Tkint...
- 用Python制作一个带图形界面的计算器
-
大家好,今天我要带大家使用Python制作一个具有图形界面的计算器应用程序。这个项目不仅可以帮助你巩固Python编程基础,还可以让你初步体验图形化编程的乐趣。我们将使用Python的tkinter库...
- 用python怎么做最简单的桌面计算器
-
有网友问,用python怎么做一个最简单的桌面计算器。如果只强调简单,在本机运行,不考虑安全性和容错等的话,你能想到的最简单的方案是什么呢?我觉得用tkinter加eval就够简单的。现在开整。首先创...
- 说好的《Think Python 2e》更新呢!
-
编程派微信号:codingpy本周三脱更了,不过发现好多朋友在那天去访问《ThinkPython2e》的在线版,感觉有点对不住呢(实在是没抽出时间来更新)。不过还好本周六的更新可以实现,要不就放一...
- 构建AI系统(三):使用Python设置您的第一个MCP服务器
-
是时候动手实践了!在这一部分中,我们将设置开发环境并创建我们的第一个MCP服务器。如果您从未编写过代码,也不用担心-我们将一步一步来。我们要构建什么还记得第1部分中Maria的咖啡馆吗?我们正在创...
- 函数还是类?90%程序员都踩过的Python认知误区
-
那个深夜,你在调试代码,一行行检查变量类型。突然,一个TypeError错误蹦出来,你盯着那句"strobjectisnotcallable",咖啡杯在桌上留下了一圈深色...
- 《Think Python 2e》中译版更新啦!
-
【回复“python”,送你十本电子书】又到了周三,一周快过去一半了。小编按计划更新《ThinkPython2e》最新版中译。今天更新的是第五章:条件和递归。具体内容请点击阅读原文查看。其他章节的...
- Python mysql批量更新数据(兼容动态数据库字段、表名)
-
一、应用场景上篇文章我们学会了在pymysql事务中批量插入数据的复用代码,既然有了批量插入,那批量更新和批量删除的操作也少不了。二、解决思路为了解决批量删除和批量更新的问题,提出如下思路:所有更新语...
- Python Pandas 库:解锁 combine、update 和compare函数的强大功能
-
在Python的数据处理领域,Pandas库提供了丰富且实用的函数,帮助我们高效地处理和分析数据。今天,咱们就来深入探索Pandas库中四个功能独特的函数:combine、combine_fi...
- 记录Python3.7.4更新到Python.3.7.8
-
Python官网Python安装包下载下载文件名称运行后选择升级选项等待安装安装完毕打开IDLE使用Python...
- Python千叶网原图爬虫:界面化升级实践
-
该工具以Python爬虫技术为核心,实现千叶网原图的精准抓取,突破缩略图限制,直达高清资源。新增图形化界面(GUI)后,操作门槛大幅降低:-界面集成URL输入、存储路径选择、线程设置等核心功能,...
- __future__模块:Python语言版本演进的桥梁
-
摘要Python作为一门持续演进的编程语言,在版本迭代过程中不可避免地引入了破坏性变更。__future__模块作为Python兼容性管理的核心机制,为开发者提供了在旧版本中体验新特性的能力。本文深入...
- Python 集合隐藏技能:add 与 update 的致命区别,90% 开发者都踩过坑
-
add函数的使用场景及错误注意添加单一元素:正确示例:pythons={1,2}s.add(3)print(s)#{1,2,3}错误场景:试图添加可变对象(如列表)会报错(Pytho...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python读取文件夹下所有文件 (59)
- java调用python脚本 (56)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)