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

别再只用MD5存密码了!聊聊Java里如何用‘盐’给密码加把锁(附代码示例)

别再只用MD5存密码了聊聊Java里如何用‘盐’给密码加把锁最近在代码审查时发现一个典型问题某位同事将用户密码直接用MD5哈希后存入数据库。这种看似安全的做法实际上隐藏着严重的安全隐患。想象一下如果数据库被拖库攻击者只需用彩虹表就能轻松破解大部分弱密码。这让我想起2012年LinkedIn的密码泄露事件——当时有超过1.17亿条仅用MD5保护的密码被破解。1. 为什么单纯MD5不安全MD5算法自1992年问世以来已被证明存在多种安全漏洞。2004年王小云教授团队公开了MD5的碰撞攻击方法能在短时间内找到两个不同输入产生相同哈希值。虽然这并不直接导致密码破解但已经动摇了MD5作为密码存储基础的可靠性。主要风险点彩虹表攻击预先计算常见密码的MD5值建立反向查询数据库碰撞攻击不同密码可能产生相同哈希值虽然概率极低无成本暴力破解现代GPU每秒可计算数十亿次MD5哈希// 典型的不安全实现示例 String unsafePassword DigestUtils.md5Hex(password123); // 输出482c811da5d5b4bc6d497ffa98491e38这个简单的例子中任何使用password123作为密码的用户其数据库记录都会显示相同的MD5值。攻击者只需查询公开的MD5数据库就能立即获得原始密码。2. 加盐加密的原理与实现加盐Salting是在密码哈希过程中引入随机数据的技术使得即使相同的密码也会产生不同的哈希值。正确的加盐应该满足每个用户拥有唯一的盐值盐值足够长建议至少16字节盐值应使用密码学安全的随机数生成器产生Java中实现加盐MD5的推荐方式import org.apache.commons.codec.digest.DigestUtils; import java.security.SecureRandom; import org.apache.commons.codec.binary.Hex; public class PasswordUtil { private static final int SALT_LENGTH 16; public static String generateSalt() { byte[] salt new byte[SALT_LENGTH]; new SecureRandom().nextBytes(salt); return Hex.encodeHexString(salt); } public static String hashPassword(String password, String salt) { String saltedPassword salt password; return DigestUtils.md5Hex(saltedPassword); } }使用示例String userPassword mySecret123; String salt PasswordUtil.generateSalt(); String hashedPassword PasswordUtil.hashPassword(userPassword, salt); // 存储 salt 和 hashedPassword 到数据库3. 进阶安全实践虽然加盐MD5比纯MD5安全但在高安全要求场景下仍不够理想。考虑以下增强措施3.1 使用更安全的哈希算法算法安全性Java支持推荐强度MD5低是不推荐SHA-256中是一般场景bcrypt高需库支持推荐PBKDF2高内置推荐Argon2极高需库支持高安全// 使用PBKDF2的示例实现 public static String hashWithPBKDF2(String password, String salt) { int iterations 10000; int keyLength 256; PBEKeySpec spec new PBEKeySpec( password.toCharArray(), salt.getBytes(), iterations, keyLength ); SecretKeyFactory factory SecretKeyFactory.getInstance(PBKDF2WithHmacSHA256); byte[] hash factory.generateSecret(spec).getEncoded(); return Hex.encodeHexString(hash); }3.2 多重哈希的误区有些开发者认为多次哈希可以提高安全性例如// 不推荐的多重哈希做法 String multiHash DigestUtils.md5Hex( DigestUtils.md5Hex( DigestUtils.md5Hex(password) ) );这种做法实际上不能有效防御彩虹表攻击专用彩虹表可破解增加了计算开销但安全性提升有限可能引入新的安全漏洞4. 生产环境最佳实践在实际项目中建议采用以下密码存储策略使用专业库如Spring Security的BCryptPasswordEncoder自动处理盐值选择能自动生成和管理盐值的算法适当调整计算成本根据硬件性能设置合理的迭代次数定期评估算法强度关注安全社区的最新建议// Spring Security的BCrypt实现示例 Bean public PasswordEncoder passwordEncoder() { return new BCryptPasswordEncoder(12); // 强度因子12 } // 使用示例 String encodedPassword passwordEncoder().encode(rawPassword); boolean matches passwordEncoder().matches(rawPassword, encodedPassword);关键注意事项永远不要自己实现加密算法避免在日志或异常信息中泄露密码相关信息考虑使用硬件安全模块(HSM)保护加密密钥定期进行安全审计和渗透测试在一次金融项目审计中我们发现使用bcrypt的密码存储方案成功抵御了针对数据库泄露的彩虹表攻击而同期另一个使用加盐MD5的系统则有约15%的密码被破解。这充分证明了选择正确算法的重要性。

相关文章:

别再只用MD5存密码了!聊聊Java里如何用‘盐’给密码加把锁(附代码示例)

别再只用MD5存密码了!聊聊Java里如何用‘盐’给密码加把锁 最近在代码审查时发现一个典型问题:某位同事将用户密码直接用MD5哈希后存入数据库。这种看似"安全"的做法,实际上隐藏着严重的安全隐患。想象一下,如果数据库被…...

光子内存计算技术:原理、挑战与工程实践

1. 光子内存计算的技术演进与挑战在半导体工艺逼近物理极限的今天,传统CMOS技术面临着互联电阻增加和电容耦合效应加剧的严峻挑战。我曾参与过多个高性能计算芯片的设计项目,亲眼见证了晶体管尺寸微缩带来的边际效益递减现象——当工艺节点进入7nm以下时…...

Arm Cortex-A35处理器架构解析与优化实践

1. Arm Cortex-A35处理器架构解析作为Armv8-A架构家族中的低功耗成员,Cortex-A35在嵌入式和高能效计算领域占据重要地位。这款处理器完美平衡了性能与功耗,特别适合物联网终端、可穿戴设备和边缘计算节点等场景。我在实际芯片设计项目中多次采用A35作为协…...

VSCode写C/C++项目必看:手把手配置.clangd和clang-tidy,实现跨文件头文件自动补全与代码规范检查

VSCode打造专业级C/C开发环境:clangd与clang-tidy深度配置指南 在当今快节奏的软件开发领域,C/C开发者面临着前所未有的效率挑战。传统IDE虽然功能强大,但往往笨重且难以定制;而轻量级编辑器又缺乏对复杂C/C项目的深度支持。这正是…...

如何快速获取八大网盘直链下载地址:LinkSwift网盘助手完整指南

如何快速获取八大网盘直链下载地址:LinkSwift网盘助手完整指南 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘…...

利用 Taotoken 模型广场为不同任务选择性价比最优模型

利用 Taotoken 模型广场为不同任务选择性价比最优模型 1. 理解模型选型的基本维度 在 Taotoken 模型广场中,每个模型都标注了核心能力标签与计费单价。开发者需要关注三个关键维度:任务类型匹配度、性能表现与成本消耗。任务类型匹配度指模型是否针对特…...

为你的AI智能体项目选择Taotoken作为稳定可靠的后端模型服务

为你的AI智能体项目选择Taotoken作为稳定可靠的后端模型服务 1. 智能体项目对模型服务的核心需求 在构建基于大模型的智能体或自动化工作流时,开发者通常面临模型服务稳定性与多模型支持的挑战。智能体需要持续响应外部输入并生成可靠输出,这就要求后端…...

从账单明细看Taotoken按Token计费如何助力精细节省成本

从账单明细看Taotoken按Token计费如何助力精细节省成本 1. 账单明细的核心价值 Taotoken的账单系统提供了按Token粒度的详细消耗记录,这是实现成本精细化管理的基础。每一条API调用记录都会包含模型名称、任务类型、输入输出Token数以及对应费用。这种透明化的计费…...

电机矢量控制技术:从原理到DSP实现

1. 电机控制技术演进:从标量控制到矢量控制 在工业自动化与电力电子领域,电机控制技术经历了从简单到复杂的演进过程。传统标量控制(Scalar Control)采用电压/频率(V/F)恒定比控制方式,通过调节…...

ESP32-S3开发板硬件解析与低功耗实践

1. 开箱即用的ESP32-S3全功能开发板深度解析第一次拿到Waveshare这款ESP32-S3-Touch-AMOLED-1.8开发板时,最让我惊讶的是它近乎完整的硬件生态集成——在不到信用卡1/3大小的空间里,AMOLED触摸屏、麦克风、扬声器、IMU传感器、RTC时钟这些物联网典型外设…...

C语言高性能内存池设计:从原理到实战,优化系统编程内存管理

1. 项目概述与核心价值 最近在整理个人技术栈和开源项目时,我重新审视了一个名为“void-memory”的仓库。这个项目名听起来有点抽象,像是某种哲学概念或者底层系统工具。实际上,它是我几年前为了解决一个非常具体且普遍的问题而构建的一个轻量…...

保姆级教程:在CentOS 7上用Docker搞定Apache Superset,从镜像拉取到汉化配置一条龙

CentOS 7下Docker部署Apache Superset全流程实战指南 在数据驱动的时代,一个强大且易用的数据可视化平台能极大提升分析效率。Apache Superset作为Airbnb开源的BI工具,凭借其丰富的可视化类型和直观的交互体验,已成为众多企业的首选。本文将带…...

N_m3u8DL-CLI-SimpleG:5分钟掌握流媒体下载的终极图形化方案

N_m3u8DL-CLI-SimpleG:5分钟掌握流媒体下载的终极图形化方案 【免费下载链接】N_m3u8DL-CLI-SimpleG N_m3u8DL-CLIs simple GUI 项目地址: https://gitcode.com/gh_mirrors/nm3/N_m3u8DL-CLI-SimpleG 你是否曾因复杂的命令行工具而对流媒体下载望而却步&…...

ESP固件烧录终极指南:5分钟掌握esptool完整工作流

ESP固件烧录终极指南:5分钟掌握esptool完整工作流 【免费下载链接】esptool Serial utility for flashing, provisioning, and interacting with Espressif SoCs 项目地址: https://gitcode.com/gh_mirrors/es/esptool esptool是乐鑫科技官方推出的Python工具…...

Go语言游戏开发框架gozen:模块化ECS架构与高性能实践

1. 项目概述:一个游戏开发者的Go语言工具集如果你在游戏开发这条路上摸爬滚打过一段时间,尤其是在尝试用Go语言(Golang)来做一些原型、工具或者服务器端逻辑,大概率会和我有同样的感受:Go的标准库很强大&am…...

揭秘QueryExcel:如何用技术革新Excel批量检索体验

揭秘QueryExcel:如何用技术革新Excel批量检索体验 【免费下载链接】QueryExcel 多Excel文件内容查询工具。 项目地址: https://gitcode.com/gh_mirrors/qu/QueryExcel 在数据驱动的现代办公环境中,Excel文件已成为企业信息存储的基石。然而&#…...

别再乱选模型了!Fluent中DPM、DEM、PBM到底怎么选?从颗粒体积分数和相互作用力讲起

别再乱选模型了!Fluent中DPM、DEM、PBM到底怎么选?从颗粒体积分数和相互作用力讲起 在计算流体动力学(CFD)模拟中,颗粒流动问题一直是工程师和研究人员面临的挑战之一。无论是气力输送系统中的煤粉流动,还是…...

鸣潮自动化终极指南:如何用ok-ww实现后台自动战斗和智能资源收集

鸣潮自动化终极指南:如何用ok-ww实现后台自动战斗和智能资源收集 【免费下载链接】ok-wuthering-waves 鸣潮 后台自动战斗 自动刷声骸 一键日常 Automation for Wuthering Waves 项目地址: https://gitcode.com/GitHub_Trending/ok/ok-wuthering-waves 还在为…...

SWIFT vs. HuggingFace PEFT:微调Llama 3时,我为什么最终选择了它?

SWIFT vs. HuggingFace PEFT:微调Llama 3的技术选型深度解析 当我在为客服对话系统选择Llama 3-8B-Instruct的微调框架时,SWIFT和HuggingFace的PEFT这两个主流选项让我陷入了深思。作为从业多年的AI工程师,我深知框架选择会直接影响迭代效率、…...

别再纠结MySQL了!用MongoDB存储AI聊天记录,Spring Boot实战代码全解析

别再纠结MySQL了!用MongoDB存储AI聊天记录,Spring Boot实战代码全解析 在构建AI对话系统时,数据存储方案的选择往往成为技术决策的痛点。传统关系型数据库如MySQL虽然成熟稳定,但在处理半结构化、快速迭代的聊天数据时&#xff0c…...

Goland实战:除了Hello World,你的第一个Go项目还能这样玩(附赠实用工具类代码)

Goland实战:除了Hello World,你的第一个Go项目还能这样玩(附赠实用工具类代码) 刚学完Go语言的Hello World,是不是觉得少了点什么?那种在终端打印一行文字的成就感,很快就会被"接下来该做什…...

SignatureTools技术深度解析:安卓APK签名与渠道管理的3大核心机制

SignatureTools技术深度解析:安卓APK签名与渠道管理的3大核心机制 【免费下载链接】SignatureTools 🎡使用JavaFx编写的安卓Apk签名&渠道写入工具,方便快速进行v1&v2签名。 项目地址: https://gitcode.com/gh_mirrors/si/Signature…...

量子误差缓解与张量网络在NISQ时代的应用

1. 量子误差缓解:NISQ时代的噪声对抗策略量子计算正经历从理论走向实践的关键转型期,但噪声问题始终是横亘在实用化道路上的主要障碍。在无法实现完全容错的现阶段,量子误差缓解(Quantum Error Mitigation, QEM)技术成…...

PWM技术与函数发生器应用详解

1. PWM技术基础与函数发生器应用概述 脉冲宽度调制(PWM)作为数字控制领域的核心技术,其本质是通过调节数字脉冲的占空比(Duty Cycle)来实现模拟信号的等效控制。我在工业自动化项目中首次接触PWM技术是在2012年设计一个伺服电机控制系统时,当时使用普通信…...

CoolProp热力学计算引擎:开源实现与工程实践深度解析

CoolProp热力学计算引擎:开源实现与工程实践深度解析 【免费下载链接】CoolProp Thermophysical properties for the masses 项目地址: https://gitcode.com/gh_mirrors/co/CoolProp 引言:热力学计算的工程挑战 在能源系统设计、制冷工程、化工过…...

构建系统提示词探索器:工程化优化大语言模型应用性能

1. 项目概述:一个系统提示词探索器的诞生最近在折腾大语言模型应用开发的朋友,估计都绕不开一个核心问题:如何设计一个真正好用、能稳定发挥模型潜能的系统提示词(System Prompt)?这玩意儿就像是给AI大脑安…...

告别print!在Flutter中优雅替换调试输出:Logger插件配置、自定义输出与性能对比

Flutter日志革命:从print到Logger的全链路升级指南 如果你还在Flutter项目中使用print来调试代码,那么你可能正在错过一个更高效、更专业的开发体验。想象一下这样的场景:当应用在生产环境崩溃时,你只能看到一堆杂乱无章的打印信息…...

机器人记忆能力评估与优化实践指南

1. 项目背景与核心价值去年在开发服务机器人项目时,我们团队遇到了一个棘手问题:不同型号的机器人在执行相同任务时,表现差异巨大。有的机器人能准确记住三个月前的用户偏好,有的却连昨天设定的工作流程都会混淆。这促使我们开始系…...

CocosCreator 3.x ScrollView性能优化实战:告别卡顿,实现类TableView的流畅列表

CocosCreator 3.x ScrollView性能优化实战:告别卡顿,实现类TableView的流畅列表 在游戏开发中,滚动列表是极其常见的UI组件,无论是排行榜、背包系统还是聊天界面,都离不开它的身影。然而,当列表项数量激增时…...

UI粒子特效穿帮了?用这个Camera技巧让特效完美贴合你的Unity界面

UI粒子特效穿帮?三招Camera技巧让特效完美贴合Unity界面 刚完成一套华丽的粒子特效,兴奋地拖到UI界面上——结果要么被UI元素完全遮挡,要么在半空中诡异漂浮。这种"穿帮现场"几乎每个Unity开发者都遇到过。上周团队新来的特效师就…...