使用自制工具类实现安全的密码加密与校验

embedded/2025/3/1 1:05:28/

在现代应用中,密码的安全性至关重要。为了保护用户密码,我们通常会对密码进行加密存储,并在用户登录时进行校验。本文将介绍如何使用 PasswordEncryptionUtil 工具类实现密码的加密与校验。


工具类介绍

PasswordEncryptionUtil 是一个基于 BCrypt 算法的密码加密工具类,提供了以下两个核心方法:

  1. encodePassword(String rawPassword)
    用于对原始密码进行加密,返回加密后的字符串。

  2. matches(String rawPassword, String encodedPassword)
    用于校验原始密码是否与加密后的密码匹配,返回布尔值。


为什么选择 BCrypt?

BCrypt 是一种广泛使用的密码哈希算法,具有以下优点:

  1. 安全性高BCrypt 使用盐值(salt)和多次哈希迭代,有效抵御彩虹表攻击。
  2. 自动盐值管理BCrypt 在加密时会自动生成盐值,并将其嵌入到加密结果中,无需额外存储。
  3. 可配置的复杂度:通过调整哈希迭代次数,可以控制加密的复杂度。

使用步骤

1. 添加依赖

首先,确保项目中引入了 jBCrypt 依赖。如果使用 Maven,可以在 pom.xml 中添加以下依赖:

<dependency><groupId>org.mindrot</groupId><artifactId>jbcrypt</artifactId><version>0.4</version>
</dependency>

2. 加密密码

在用户注册或修改密码时,使用 encodePassword 方法对密码进行加密:

String rawPassword = "user123"; // 用户输入的原始密码
String encodedPassword = PasswordEncryptionUtil.encodePassword(rawPassword);
System.out.println("加密后的密码: " + encodedPassword);

输出示例

加密后的密码: $2a$10$3zYbJZ5Z5Z5Z5Z5Z5Z5Z5u

3. 校验密码

在用户登录时,使用 matches 方法校验密码是否匹配:

String rawPassword = "user123"; // 用户输入的原始密码
String encodedPassword = "$2a$10$3zYbJZ5Z5Z5Z5Z5Z5Z5Z5u"; // 数据库中存储的加密密码boolean isMatch = PasswordEncryptionUtil.matches(rawPassword, encodedPassword);
System.out.println("密码是否匹配: " + isMatch);

输出示例

密码是否匹配: true

实际应用场景

场景 1:用户注册

在用户注册时,对密码进行加密并存储到数据库:

public void registerUser(String username, String rawPassword) {String encodedPassword = PasswordEncryptionUtil.encodePassword(rawPassword);// 将 username 和 encodedPassword 存储到数据库userRepository.save(new User(username, encodedPassword));
}

场景 2:用户登录

在用户登录时,校验密码是否匹配:

public boolean loginUser(String username, String rawPassword) {User user = userRepository.findByUsername(username);if (user == null) {return false; // 用户不存在}return PasswordEncryptionUtil.matches(rawPassword, user.getEncodedPassword());
}

场景 3:修改密码

在用户修改密码时,对新密码进行加密并更新数据库:

public void changePassword(String username, String newRawPassword) {String newEncodedPassword = PasswordEncryptionUtil.encodePassword(newRawPassword);// 更新数据库中的密码userRepository.updatePassword(username, newEncodedPassword);
}

注意事项

  1. 密码强度
    在加密前,建议对原始密码进行强度校验,确保密码符合安全要求(如长度、复杂度等)。

  2. 加密结果长度
    BCrypt 的加密结果长度固定为 60 个字符,数据库字段应预留足够空间。

  3. 性能优化
    BCrypt 的哈希迭代次数可以通过 BCrypt.gensalt(int log_rounds) 调整,默认值为 10。较高的迭代次数会增加安全性,但也会增加计算时间。

  4. 错误处理
    在实际应用中,应对加密和校验过程中的异常进行捕获和处理,例如:

    try {String encodedPassword = PasswordEncryptionUtil.encodePassword(rawPassword);
    } catch (Exception e) {// 处理加密失败的情况
    }
    

总结

PasswordEncryptionUtil 工具类基于 BCrypt 算法,提供了简单易用的密码加密与校验功能。通过本文的介绍,您可以在项目中轻松实现密码的安全管理,有效保护用户数据。希望这篇博客对您有所帮助!如果有任何问题,欢迎留言讨论。


附录:完整工具类代码

package com.paoxiaomo.teachingassistant.utils;import org.mindrot.jbcrypt.BCrypt;public class PasswordEncryptionUtil {/*** 加密密码** @param rawPassword 原始密码* @return 加密后的密码*/public static String encodePassword(String rawPassword) {// 生成盐值并加密密码return BCrypt.hashpw(rawPassword, BCrypt.gensalt());}/*** 校验密码是否匹配** @param rawPassword      原始密码* @param encodedPassword  加密后的密码* @return 校验结果,true 为匹配,false 为不匹配*/public static boolean matches(String rawPassword, String encodedPassword) {// 校验原始密码和加密后的密码是否匹配return BCrypt.checkpw(rawPassword, encodedPassword);}
}

http://www.ppmy.cn/embedded/168924.html

相关文章

达梦数据库授权给某个用户查询其他指定用户下所有表的权限

方法1&#xff1a; 新版本有一个数据库参数 GRANT_SCHEMA&#xff0c;表示是否开启授予和回收模式权限功能。0&#xff1a;否&#xff1b;1&#xff1a;是 此参数为静态参数&#xff0c;默认是0&#xff0c;将改参数修改为1后&#xff0c;重启数据库生效。 将参数修改为1 S…

深入了解 NAT 模式:网络地址转换的奥秘

深入了解 NAT 模式&#xff1a;网络地址转换的奥秘 在计算机网络的世界里&#xff0c;NAT 模式&#xff08;Network Address Translation&#xff0c;网络地址转换&#xff09;扮演着至关重要的角色。它就像是网络中的翻译官&#xff0c;在不同网络地址之间进行转换&#xff0…

Mysql 死锁场景及解决方案

一、常见死锁场景 1. 不同顺序的锁获取 场景&#xff1a;事务A按顺序更新 行1 → 行2&#xff0c;事务B按 行2 → 行1 顺序更新。 原因&#xff1a;双方各持有一把锁&#xff0c;同时请求对方持有的锁&#xff0c;形成循环等待。 2. 索引缺失导致锁升级 场景&#xff1a;更…

List的模拟实现(2)

前言 上一节我们讲解了list的基本功能&#xff0c;那么本节我们就结合底层代码来分析list是怎么实现的&#xff0c;那么废话不多说&#xff0c;我们正式进入今天的学习&#xff1a;&#xff09; List的底层结构 我们先来看一下list的底层基本结构&#xff1a; 这里比较奇怪的…

AndroidStudio下载旧版本方法

首先&#xff0c;打开Android Studio的官网&#xff1a;https://developer.android.com/studio。 然后&#xff0c;点击【Read release notes】。 然后需要将语言切换成英文&#xff0c;否则会刷不出来。 然后就可以看下各个历史版本了。 直接点链接好像也行&#xff1a;h…

YOLOv8+QT搭建目标检测项目

2024年7月YOLOv8QT初步搭建目标检测&#xff08;避坑&#xff09;_qt yolov8-CSDN博客YOLOv8QT初步搭建目标检测 2024年7月YOLOv8QT初步搭建目标检测&#xff08;避坑&#xff09;_qt yolov8-CSDN博客 yolov8的可视化界面&#xff08;一、可视化界面设计&#xff09;_yolo 可…

‌KNN算法优化实战分享——基于空间数据结构的工业级实战指南

‌作者&#xff1a;‌ 某大厂空间计算架构师 ‌发布日期&#xff1a;2025年02月27日‌ ‌适用场景&#xff1a;地理信息系统&#xff08;GIS&#xff09;、自动驾驶、物流调度等海量空间数据查询‌ ‌一、生产环境代码模板‌ 1.1 KD-Tree批量化构建与查询&#xff08;千万级数…

3分钟idea接入deepseek

DeepSeek简介 DeepSeek 是杭州深度求索人工智能基础技术研究有限公司开发的一系列大语言模型&#xff0c;背后是知名量化资管巨头幻方量化3。它专注于开发先进的大语言模型和相关技术&#xff0c;拥有多个版本的模型&#xff0c;如 DeepSeek-LLM、DeepSeek-V2、DeepSeek-V3 等&…