当前位置: 首页 > news >正文

[1364]bcrypt用法--密码哈希

文章目录

      • 📦 安装与准备
      • 🔐 密码哈希生成
      • ✅ 密码验证
      • ⚙️ 进阶用法与注意事项

bcrypt是 Python 中用于安全存储密码的哈希库,基于 Blowfish 算法,具备加盐(Salt)和可调工作因子(Work Factor)特性,能有效抵御彩虹表和暴力破解攻击。注意:它是单向哈希,不可解密。

Python 的bcrypt库是专门用于密码哈希的,它的核心用法就是生成哈希验证密码,用起来并不复杂。下面我把它的主要用法和注意事项整理了一下。

📦 安装与准备

首先,用 pip 安装 bcrypt 库:

pipinstallbcrypt

使用时,需要注意密码和盐值都需要是字节(bytes)类型,不是普通的字符串。通常用.encode('utf-8')转换。

🔐 密码哈希生成

1. 生成盐值
盐值是一串随机字符,用来和密码混合,防止彩虹表攻击。使用gensalt()函数生成,可以指定rounds参数来控制计算强度(默认12,推荐12-14)。

importbcrypt# 生成一个默认强度的盐值 (rounds=12)salt=bcrypt.gensalt()# 生成一个强度更高 (rounds=14) 的盐值salt_high_cost=bcrypt.gensalt(rounds=14)

2. 生成哈希
使用hashpw()函数,将密码盐值作为参数传入,得到一个完整的、包含盐值的哈希值。

password=b"my_secret_password"salt=bcrypt.gensalt()# 生成哈希值,可以安全地存入数据库hashed_password=bcrypt.hashpw(password,salt)print(hashed_password)# 输出类似: b'$2b$12$lQ.....'

注意:生成的哈希值里已经包含了盐值和版本等信息,不需要单独存储盐值

✅ 密码验证

验证时,使用checkpw()函数,传入用户输入的明文密码之前存储的哈希值。它会自动从哈希值中提取盐值,重新计算并比对。

# 模拟从数据库读取的哈希值stored_hash=b'$2b$12$lQ.....'# 用户登录时输入的密码user_input_password=b"my_secret_password"# 验证,返回 True 或 Falseis_correct=bcrypt.checkpw(user_input_password,stored_hash)ifis_correct:print("密码正确")else:print("密码错误")

⚙️ 进阶用法与注意事项

  • 调整工作因子 (rounds)rounds参数控制哈希计算迭代次数(2^rounds次),值越大越安全,但计算耗时也越长。你需要根据服务器性能来平衡。

    # 示例:使用 rounds=14salt=bcrypt.gensalt(rounds=14)
  • 密码长度限制:bcrypt 内部只处理密码的前72 个字节,超出的部分会被忽略。为了安全,最好在业务层对密码长度做出限制,例如在前端和后端都限制在 72 个字符以内,并给出清晰提示。

  • 密钥派生 (kdf):除了常规的密码哈希,bcrypt 还提供了一个kdf()函数,可以从密码生成固定长度的加密密钥,用于其他加密场景。使用场景比较特定。

    用于生成加密密钥(非密码哈希),需指定固定盐值。

key=bcrypt.kdf(password=b"secret",salt=b"fixed_salt_16bytes!",desired_key_bytes=32,rounds=100)
  • 版本前缀:推荐使用2b前缀(gensalt(prefix=b"2b")),避免旧版2a潜在漏洞。
http://www.jsqmd.com/news/1075726/

相关文章:

  • 浏览器中的微信革命:wechat-need-web插件让你随时随地聊天
  • OAuth2 登录与群 Webhook 开放接入
  • JDK 9 的 PlatformClassLoader 只是简单改个名吗?
  • SDKMAN CLI:用 Go 重写版本管理工具的探索
  • 别再死磕SEO!AI时代新流量入口GEO,抢占AI答案推荐位
  • 一键解锁无损音乐宝藏:TIDAL Downloader Next Generation 高解析度音频下载全攻略
  • 博客系统接口需求分析:从模块拆解到自动化测试设计
  • 机器学习小数据训练实战:四维评估与高效落地方法
  • TypedDict 详解与 Dataclass 选型指南
  • 云计算作业3
  • 诊断证明翻译怎么办理?诊断证明翻译怎么线上办理?
  • 真的佩服那些能考上清华北大哈佛的人
  • H3C S5130 交换机 SSH 远程开局配置指南
  • CVE-2018-12613漏洞剖析:从文件包含到代码执行的攻防实战
  • 终极指南:如何用Python快速上手FMI模型仿真
  • LTE-M、NB-IoT、Cat-1 bis:海外部署时应该如何选
  • 16类文本主题分类系统:DistilBERT+ONNX生产实践
  • 27.继电器思维转不过来?读懂 PLC 五层扫描周期,才算真正学会 PLC 编程
  • 豆包大模型2.1 Pro发布深度解析:日均180万亿Token背后的中国AI编程新王座
  • 临时放置代码
  • 中国远程控制行业研究报告(2026):从连接工具到智能生产力基座的演进路径
  • HS2-HF Patch:游戏模组生态系统的架构演进与技术实践
  • 微软详细说明 Windows 11 版本 26H2 的支持生命周期
  • SQL注入漏洞
  • 支持合规二创的AI Remix音乐工具实操分享
  • 好物工具推荐|一站式电商活动查询站点分享
  • 如何理解 CDN 的加速原理?
  • 2026年AI论文写作软件深度评测:6款工具专业水准得分排名
  • Outfit字体:9种字重的开源几何无衬线字体如何重塑现代设计系统
  • P89LPC93xx微控制器I2C与SPI通信协议实战详解与驱动开发