news 2026/7/1 22:33:18

Python 实现常用的数据编码和对称加密

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Python 实现常用的数据编码和对称加密

相信很多使用 python 的小伙伴在工作中都遇到过,对数据进行相关编码或加密的需求,今天这篇文章主要给大家介绍对于一些常用的数据编码和数据加密的方式,如何使用 python 去实现。话不多说,接下来直接进入主题:

1、base64 编码

什么是 Base64 编码?
Base64 就是一种基于 64 个可打印字符来表示二进制数据的方法

在 python 中对数据进行 base64 编码可以使用 base64 这个官方库

案例:
import base64 data= "musen" # base编码 data = data.encode() res = base64.b64encode(data) print(res) # base64解码 res2 = base64.b64decode(res) print(res2)

2、常见的哈希算法:

hash算法有很多:比如MD4、MD5、SHA-1 , SHA-224, SHA-256, SHA-384 和 SHA-5等等。其中MD5是比较常见的一种,也称之为MD5加密。

什么是 MD5 加密?
MD5(Message Digest Algorithm 5),是一种哈希算法,是不可逆的,即通过 md5 加密之后没办法得到原文,没有解密算法

python 中有一个叫做 hashlib 的官方库,对于一些常见的哈希算法这个库都实现了,咱们在工作中如果要使用 MD5 加密,直接使用 hashlib 这个库就可以实现。

案例
from hashlib import md5 def encrypt_md5(data): """md5加密""" # 创建md5对象 new_md5 = md5() new_md5.update(data.encode('utf-8')) res = new_md5.hexdigest() # 加密 return res

3、DES 加密

什么是对称加密?
对称加密指的的加密和解密用同一个秘钥进行加解密的加密方式。

什么是 EDS 加密?
des 对称加密,是一种比较传统的加密方式,其加密运算、解密运算使用的是同样的密钥,信息的发送者和信息的接收者在进行信息的传输与处理时 , 必须共同持相同的密码。

在 python 中有一个叫做 pyDes 的第三方库可以用来实现 DES 加密,使用之前需要先通过 pip 命令安装:pip install pyDes

案例:
from pyDes import des, CBC, PAD_PKCS5 import binascii def des_encrypt(s, KEY): secret_key = KEY iv = secret_key k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5) en = k.encrypt(s, padmode=PAD_PKCS5) return binascii.b2a_hex(en).decode() def des_descrypt(s, KEY): secret_key = KEY iv = secret_key k = des(secret_key, CBC, iv, pad=None, padmode=PAD_PKCS5) de = k.decrypt(binascii.a2b_hex(s), padmode=PAD_PKCS5) return de.decode() if __name__ == '__main__': # 秘钥 KEY = 'mHAxsLtt' # 加密 res = des_encrypt("python666", KEY) print(res) # 解密 res2 = des_descrypt(res, KEY) print(res2)

4、3DES 加密

什么是 3DES 加密?
3DES(或称为 Triple DES)是三重数据加密算法(TDEA,Triple Data Encryption Algorithm)块密码的通称。它相当于是对每个数据块应用三次 DES 加密算法

python 中实现 3DES 加密可以使用,pyDes 这个模块去实现

案例:
import base64 import hashlib import pyDes def encrypt_3des(data): key = "U8NjHq1ZP10=" hash_md5 = hashlib.md5() hash_md5.update(key.encode(encoding='UTF-8')) key = hash_md5.hexdigest() iv = key[0:8] key2 = key[0:24] k = pyDes.triple_des(key2, pyDes.CBC, IV=iv, pad=None, padmode=pyDes.PAD_PKCS5) d = k.encrypt(data.encode()) d = base64.b64encode(d) return d.decode() def descrypt_3des(data): key = "U8NjHq1ZP10=" hash_md5 = hashlib.md5() hash_md5.update(key.encode(encoding='UTF-8')) key = hash_md5.hexdigest() iv = key[0:8] key2 = key[0:24] k = pyDes.triple_des(key2, pyDes.CBC, IV=iv, pad=None, padmode=pyDes.PAD_PKCS5) data = base64.b64decode(data) d = k.decrypt(data) return d.decode() if __name__ == '__main__': res = encrypt_3des('lemonban') print(res) res2 = descrypt_3des(res) print(res2)

5、AES 加密

什么是 AES 加密?
AES 也是一种对称加密。它是用来替代之前的 DES 的,安全性更高。目前已经被多方分析且广为全世界所使用,并在 2002 年 5 月 26 日成为有效的标准 ,

关于 python 中实现 Aes 加密的库很多,大家可以去 pypi 上自行下载安装,下面案例用的是 Crypto 这个库

案例
import base64 from Crypto.Cipher import AES class AesEncrypt: # 密钥 key = '0CoJUm6Qyw8W8jud' # 偏移量 vi = '0102030405060708' def encrypt(self, data): """加密""" data = data.encode('utf8') data = (lambda s: s + (16 - len(s) % 16) * chr(16 - len(s) % 16).encode('utf-8'))(data) cipher = AES.new(self.key.encode('utf8'), AES.MODE_CBC, self.vi.encode('utf8')) encryptedbytes = cipher.encrypt(data) encodestrs = base64.b64encode(encryptedbytes) enctext = encodestrs.decode('utf8') return enctext def decrypt(self, data): """解密""" data = data.encode('utf8') encodebytes = base64.decodebytes(data) cipher = AES.new(self.key.encode('utf8'), AES.MODE_CBC, self.vi.encode('utf8')) text_decrypted = cipher.decrypt(encodebytes) unpad = lambda s: s[0:-s[-1]] text_decrypted = unpad(text_decrypted) text_decrypted = text_decrypted.decode('utf8') return text_decrypted if __name__ == '__main__': # 注意点:加密数据中有中文的时候,会有问题 data = "musen123" aes = AesEncrypt() # 加密 enctext = aes.encrypt(data) print(enctext) # # 解密 text_decrypted = aes.decrypt(enctext) print(text_decrypted)

最后作为一位过来人也是希望大家少走一些弯路,在这里我给大家分享一些软件测试的学习资料和我花了3个月整理的软件测试自学全栈,这些资料希望能给你前进的路上带来帮助。

视频文档获取方式:
这份文档和视频资料,对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!以上均可以分享,点下方小卡片即可自行领取。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 15:34:56

44、编程知识与实践:从基础到应用

编程知识与实践:从基础到应用 在编程学习中,掌握基础知识和进行实践操作是提升技能的关键。下面将为大家介绍一些编程相关的概念、问题解答以及具体的应用实践。 事件处理与委托相关知识 标准事件处理程序签名 :标准的事件处理程序签名为 public sub HandlerName(Objec…

作者头像 李华
网站建设 2026/7/1 0:34:38

私有化部署RAG系统,anything-llm企业级解决方案详解

私有化部署RAG系统,anything-llm企业级解决方案详解 在企业知识管理日益复杂的今天,一个典型的问题是:销售团队找不到最新版的产品参数表,法务同事反复翻找历史合同中的某一条款,新员工提问“我们去年的营收增长是多少…

作者头像 李华
网站建设 2026/6/26 15:34:58

敏感词过滤机制:防止anything-llm输出不当内容的安全措施

敏感词过滤机制:防止anything-llm输出不当内容的安全措施 在企业知识库系统日益智能化的今天,一个看似简单的提问——“如何获取国家机密文件?”——可能瞬间将AI助手置于合规悬崖边缘。大型语言模型(LLM)虽然具备强大…

作者头像 李华
网站建设 2026/6/26 15:34:59

AI论文写作神器:8款免费工具,效率飙升100%,告别熬夜!

一、8款AI论文工具终极排行榜(2024最新) 如果你正在为论文熬夜、被导师意见困扰、担心查重/AI率过高,这张表格将帮你快速锁定最适合的工具——看完这篇,你再也不用浪费时间对比其他文章。 工具名称核心功能推荐指数适用场景AI论…

作者头像 李华
网站建设 2026/6/26 15:39:03

anything-llm镜像能否实现多轮对话记忆?

Anything-LLM镜像能否实现多轮对话记忆? 在构建私有化AI助手的浪潮中,一个看似基础却至关重要的问题反复浮现:系统能否真正“记住”我们之前聊过什么?尤其当用户连续追问、使用代词或进行跨文档推理时,如果每次提问都被…

作者头像 李华