0

0

Python密码学基础 Python加密算法库实战

冰火之心

冰火之心

发布时间:2025-06-08 09:51:01

|

816人浏览过

|

来源于php中文网

原创

python在密码学领域常用场景包括对称加密、哈希处理和非对称加密。1.使用cryptography库实现aes-gcm对称加密,可加密和解密数据,需注意nonce唯一性和密钥保密;2.用hashlib结合salt及bcrypt实现安全密码存储,避免使用md5或sha-1;3.通过pycryptodome进行rsa非对称加密,适合小数据加密和数字签名,私钥必须严格保密。这些方法覆盖了常见需求,推荐使用成熟库并遵循最佳实践以确保安全性。

Python密码学基础 Python加密算法库实战

Python 在密码学领域的应用非常广泛,尤其适合用来实现加密、解密、签名和验证等操作。如果你是刚接触这个方向的开发者,可能会对 Python 提供哪些加密库、怎么用它们做基本的加解密感到有点迷茫。其实只要掌握几个常用库和使用方式,就能快速上手实战。

下面从几个实际场景出发,说说你最可能需要用到的几种情况和做法。


使用 cryptography 做对称加密(AES)

在很多场景下,我们只需要用一个密钥来加密和解密数据,这时候对称加密是最直接的选择。常用的算法有 AES(高级加密标准),而 Python 的 cryptography 库就很好地支持它。

立即学习Python免费学习笔记(深入)”;

举个例子:你想把一段文本加密后保存到文件或数据库里,之后还能还原回来。

  • 安装方法:pip install cryptography
  • 推荐使用 AES-GCM 模式,因为它不仅加密还带认证,防止数据被篡改
from cryptography.hazmat.primitives.ciphers.aead import AESGCM
import os

key = AESGCM.generate_key(bit_length=256)
aesgcm = AESGCM(key)
nonce = os.urandom(12)  # 必须唯一且不可重复使用
data = b"这是要加密的数据"
encrypted = aesgcm.encrypt(nonce, data, None)
decrypted = aesgcm.decrypt(nonce, encrypted, None)

注意点:

  • nonce 不能重复使用,否则会破坏安全性
  • 加密后的数据通常需要连同 nonce 一起存储或传输,但不需要保密
  • 密钥必须安全保管,泄露了就等于数据也泄露了

使用 hashlib 实现哈希计算与密码存储

很多时候我们不直接存储用户密码,而是存储它的哈希值。这时候就要用到像 SHA-256、SHA-3 这类哈希算法。

比如注册登录系统中,用户输入密码后,程序应该只保留它的哈希结果:

Magic AI Avatars
Magic AI Avatars

神奇的AI头像,获得200多个由AI制作的自定义头像。

下载
import hashlib

password = b"user_password_123"
hash_obj = hashlib.sha256(password)
print(hash_obj.hexdigest())

更推荐的做法是加上 salt(盐值)并使用专门的密码哈希函数如 bcrypt 或 scrypt:

pip install bcrypt
import bcrypt

password = b"mysecretpassword"
salt = bcrypt.gensalt()
hashed = bcrypt.hashpw(password, salt)
# 验证时
if bcrypt.checkpw(password, hashed):
    print("匹配")

要点:

  • 不要用 MD5 或 SHA-1,这些已经被证明不够安全
  • 加盐是为了防止彩虹表攻击
  • 选择 bcrypt、scrypt 或 argon2 更适合密码存储

使用 PyCryptodome 实现非对称加密(RSA)

当你需要一对密钥(公钥和私钥),并且希望别人用你的公钥加密信息,只有你能用私钥解密,这时候就需要非对称加密。RSA 是常见的一种方式。

安装方法:pip install pycryptodome

生成密钥对并加密:

from Crypto.PublicKey import RSA
from Crypto.Cipher import PKCS1_OAEP

key = RSA.generate(2048)
private_key = key.export_key()
public_key = key.publickey().export_key()

# 用公钥加密
cipher_rsa = PKCS1_OAEP.new(RSA.import_key(public_key))
encrypted_data = cipher_rsa.encrypt(b"Secret message")

# 用私钥解密
cipher_rsa = PKCS1_OAEP.new(RSA.import_key(private_key))
decrypted_data = cipher_rsa.decrypt(encrypted_data)

注意事项:

  • 非对称加密适合小数据,不适合大文件
  • 一般用于传输对称密钥或签名
  • 私钥必须严格保密,丢了就无法恢复

小结

以上几种情况涵盖了大多数 Python 开发者在密码学方面的需求。你可以根据具体业务选择合适的加密方式:

  • 对称加密 → 数据量大、速度快,适合本地加密
  • 哈希处理 → 存储密码、校验完整性
  • 非对称加密 → 安全通信、数字签名

基本上就这些。别看步骤多,只要熟悉流程,用起来并不难。不过还是那句话,密码学是个专业领域,自己实现算法风险很大,最好使用成熟库,并遵循最佳实践。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
pip安装使用方法
pip安装使用方法

安装步骤:1、确保Python已经正确安装在您的计算机上;2、下载“get-pip.py”脚本;3、按下Win + R键,然后输入cmd并按下Enter键来打开命令行窗口;4、在命令行窗口中,使用cd命令切换到“get-pip.py”所在的目录;5、执行安装命令;6、验证安装结果即可。大家可以访问本专题下的文章,了解pip安装使用方法的更多内容。

373

2023.10.09

更新pip版本
更新pip版本

更新pip版本方法有使用pip自身更新、使用操作系统自带的包管理工具、使用python包管理工具、手动安装最新版本。想了解更多相关的内容,请阅读专题下面的文章。

436

2024.12.20

pip设置清华源
pip设置清华源

设置方法:1、打开终端或命令提示符窗口;2、运行“touch ~/.pip/pip.conf”命令创建一个名为pip的配置文件;3、打开pip.conf文件,然后添加“[global];index-url = https://pypi.tuna.tsinghua.edu.cn/simple”内容,这将把pip的镜像源设置为清华大学的镜像源;4、保存并关闭文件即可。

803

2024.12.23

python升级pip
python升级pip

本专题整合了python升级pip相关教程,阅读下面的文章了解更多详细内容。

371

2025.07.23

页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

497

2023.08.14

数据库三范式
数据库三范式

数据库三范式是一种设计规范,用于规范化关系型数据库中的数据结构,它通过消除冗余数据、提高数据库性能和数据一致性,提供了一种有效的数据库设计方法。本专题提供数据库三范式相关的文章、下载和课程。

386

2023.06.29

如何删除数据库
如何删除数据库

删除数据库是指在MySQL中完全移除一个数据库及其所包含的所有数据和结构,作用包括:1、释放存储空间;2、确保数据的安全性;3、提高数据库的整体性能,加速查询和操作的执行速度。尽管删除数据库具有一些好处,但在执行任何删除操作之前,务必谨慎操作,并备份重要的数据。删除数据库将永久性地删除所有相关数据和结构,无法回滚。

2111

2023.08.14

vb怎么连接数据库
vb怎么连接数据库

在VB中,连接数据库通常使用ADO(ActiveX 数据对象)或 DAO(Data Access Objects)这两个技术来实现:1、引入ADO库;2、创建ADO连接对象;3、配置连接字符串;4、打开连接;5、执行SQL语句;6、处理查询结果;7、关闭连接即可。

357

2023.08.31

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号