加盐加密算法保护用户密码 实战案例 PasswordUtil

本文主要是介绍加盐加密算法保护用户密码 实战案例 PasswordUtil,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

加盐算法(Salted Hashing)是一种密码学技术,用于增强密码的安全性。它结合了哈希算法和随机盐值的概念在传统的密码存储中,用户的密码通常是经过哈希算法处理后存储在数据库中。然而,这种方法面临着彩虹表和字典攻击等风险。

  • 彩虹表是一个预先计算好的表格,其中包含了大量的输入和对应的哈希值。攻击者可以使用彩虹表反向查找通过已知的哈希值来快速找到对应的原始密码。
  • 字典攻击是一种暴力破解技术,假设用户的密码是常见的词语、短语或常用密码的组合。攻击者使用一个包含大量常见密码、常用词语、姓名、日期等的字典文件,将其中的每个密码依次尝试,与目标账户的密码进行比对。

为了防止这些攻击,加盐算法引入了"盐”,即一个随机的、唯一的字符串。在存储用户密码时,将密码与盐值进行组合,再使用哈希算法进行处理,得到一个唯一的哈希值。这样,即使两个用户使用相同的密码,由于使用了不同的盐值,其哈希值也会不同。另外,盐值通常是不保存在数据库中的,而是与哈希值一起存储。这样,即使攻击者获取到数据库,也很难破解密码。
总体来说,加盐算法通过使用随机的盐值和哈希算法,使得相同的密码拥有不同的哈希值,增加了密码的安全性提高了用户的率码保护级别。

package com.example.common;import org.springframework.util.DigestUtils;
import org.springframework.util.StringUtils;import java.util.UUID;public class PasswordUtil {/*** 加盐算法 -> 格式:盐值(32)$加密之后的密码(32)* @param password 原密码* @return*/public static String encrypt(String password){// 1.生成盐值String salt = UUID.randomUUID().toString().replace("-","");// 2.使用加密算法将盐值+原密码进行加密String finalPassword = DigestUtils.md5DigestAsHex((salt+password).getBytes());// 3.将盐值和加密后的密码一起返回String dbPassword = salt+"$"+finalPassword;return dbPassword;}/*** 密码验证* @param inputPassword* @param dbPassword* @return*/public static boolean decrypt(String inputPassword,String dbPassword){// 1.验证参数if(!StringUtils.hasLength(inputPassword) || !StringUtils.hasLength(dbPassword) ||dbPassword.length()!=65 || !dbPassword.contains("$")){return false;}// 2.将用户输入的密码和数据库的盐值进行加密,得到待验证的加密密码// 2.1 得到盐值 & 最终正确的密码String[] dbPasswordArray = dbPassword.split("\\$");String salt = dbPasswordArray[0];String finalPassword = dbPasswordArray[1];// 2.2 使用数据库的盐值+用户输入的密码进行加密=待验证的加密密码String userPassword = DigestUtils.md5DigestAsHex((salt+inputPassword).getBytes());// 3.将待验证密的加密密码和数据的加密的密码进行对比if(userPassword.equals(finalPassword)){return true;}// 4.将结果返回给调用方return false;}
}

这篇关于加盐加密算法保护用户密码 实战案例 PasswordUtil的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1057984

相关文章

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python办公自动化实战之打造智能邮件发送工具

《Python办公自动化实战之打造智能邮件发送工具》在数字化办公场景中,邮件自动化是提升工作效率的关键技能,本文将演示如何使用Python的smtplib和email库构建一个支持图文混排,多附件,多... 目录前言一、基础配置:搭建邮件发送框架1.1 邮箱服务准备1.2 核心库导入1.3 基础发送函数二、

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

PostgreSQL的扩展dict_int应用案例解析

《PostgreSQL的扩展dict_int应用案例解析》dict_int扩展为PostgreSQL提供了专业的整数文本处理能力,特别适合需要精确处理数字内容的搜索场景,本文给大家介绍PostgreS... 目录PostgreSQL的扩展dict_int一、扩展概述二、核心功能三、安装与启用四、字典配置方法

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

Spring Security中用户名和密码的验证完整流程

《SpringSecurity中用户名和密码的验证完整流程》本文给大家介绍SpringSecurity中用户名和密码的验证完整流程,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定... 首先创建了一个UsernamePasswordAuthenticationTChina编程oken对象,这是S

Java MQTT实战应用

《JavaMQTT实战应用》本文详解MQTT协议,涵盖其发布/订阅机制、低功耗高效特性、三种服务质量等级(QoS0/1/2),以及客户端、代理、主题的核心概念,最后提供Linux部署教程、Sprin... 目录一、MQTT协议二、MQTT优点三、三种服务质量等级四、客户端、代理、主题1. 客户端(Clien

在Spring Boot中集成RabbitMQ的实战记录

《在SpringBoot中集成RabbitMQ的实战记录》本文介绍SpringBoot集成RabbitMQ的步骤,涵盖配置连接、消息发送与接收,并对比两种定义Exchange与队列的方式:手动声明(... 目录前言准备工作1. 安装 RabbitMQ2. 消息发送者(Producer)配置1. 创建 Spr