首页
/ JohnTheRipper 项目新增 PostgreSQL SCRAM-SHA-256 哈希支持的技术解析

JohnTheRipper 项目新增 PostgreSQL SCRAM-SHA-256 哈希支持的技术解析

2025-05-21 19:09:21作者:平淮齐Percy

在密码安全领域,JohnTheRipper 作为一款知名的开源密码分析工具,持续扩展其对各类哈希算法的支持。近期开发团队针对 PostgreSQL 数据库特有的 SCRAM-SHA-256 认证机制实现了兼容支持,这一技术演进值得深入探讨。

技术背景

PostgreSQL 从 10.0 版本开始引入 SCRAM-SHA-256 作为默认认证方式,其密码存储格式具有特定结构:

SCRAM-SHA-256$<迭代次数>:<Base64盐值>$<Base64存储密钥>:<Base64服务端密钥>

这种格式与传统的 MongoDB SCRAM 实现存在两个关键差异:

  1. 字段间使用冒号分隔而非标准SCRAM的逗号
  2. 盐值长度不固定(不同于MongoDB的固定长度)

实现挑战

开发过程中面临两个主要技术难点:

  1. 分隔符兼容性问题 原始代码仅支持标准SCRAM的逗号分隔格式,需要扩展解析逻辑以处理PostgreSQL特有的冒号分隔符。团队选择通过prepare方法实现格式转换,而非单独开发2john脚本,这保持了代码架构的统一性。

  2. 动态盐值长度支持 原实现硬编码了盐值长度校验(针对MongoDB),导致无法正确处理PostgreSQL的可变长度盐值。解决方案是移除长度限制,同时确保安全参数检查。

技术实现细节

核心改进包括:

  1. 增强的格式解析器 新增支持解析如下典型格式:
SCRAM-SHA-256$4096:Wn/IWH721Aj+HbEQRJiD3A==$xtjWYz23fPW4dXUZMzTup6bUOqSAVzlChcrhHCfIXfo=:EyLID0avoAyy1JzKwD7yKQ9HuWQ0VlSurm180/sQFYE=
  1. 输出优化 当前--show功能输出包含密码和部分哈希组分,未来可能优化为更简洁的显示方式。示例输出:
user:test:L6Nhfyy6pos5mpvTRXQOTQ==$...(略)

安全实践建议

对于使用PostgreSQL的管理员:

  1. 建议迭代次数设置为10000以上
  2. 定期检查pg_authid表中的密码哈希格式
  3. 考虑使用\password命令定期更新密码

对于安全研究人员:

  1. 测试时注意区分MongoDB和PostgreSQL的SCRAM实现差异
  2. 可利用新支持验证数据库密码强度

未来方向

团队计划进一步优化哈希显示格式,并探索对其他数据库SCRAM变体的支持。此次升级体现了JohnTheRipper对新兴认证标准的快速响应能力,为数据库安全审计提供了更完备的工具支持。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
260
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
858
507
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
255
299
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
331
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
397
370
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
21
5