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

SpringSecurity密码编码器:使用BCrypt算法加密、自定义密码编码器

1、Spring Security 密码编码器

Spring Security 作为一个功能完备的安全性框架,一方面提供用于完成加密操作的 PasswordEncoder 组件,另一方面提供一个可以在应用程序中独立使用的密码模块。

1.1 PasswordEncoder 抽象接口

在 Spring Security 中,PasswordEncoder 接口代表的是一种密码编码器,用于指定密码的具体加密方式,以及如何在给定的一段加密字符串与明文之间完成匹配校验。

PasswordEncoder 接口定义如下:

package org.springframework.security.crypto.password;public interface PasswordEncoder
{//对原始密码进行编译String encode(CharSequence var1);//对提交的原始密码与库中存储的加密密码进行比对boolean matches(CharSequence var1, String var2);//判断加密密码是否需要再次进行加密,默认返回 falsedefault boolean upgradeEncoding(String encodedPassword){return false;}
}

1.2 内置的 PasswordEncoder 接口实现类

Spring Security 内置了一大批 PasswordEncoder 接口的实现类,比较常见的 PasswordEncoder 实现类集体解释如下:

实现类说明
NoOpPasswordEncoder以明文形式保存密码,不对密码进行编码。这种 PasswordEncoder 实现类通常只用于演示,不建议用于生成环境。
StandardPasswordEncoder使用 SHA-256 算法对密码执行散列操作。
BCryptPasswordEncoder使用 BCrypt 强散列算法对密码执行散列操作。
Pbkdf2PasswordEncoder使用 PBKDF2 算法对密码执行散列操作。

2、Spring Security 使用 BCrypt 算法加密与校验

BCrypt 加密是一种安全且高效的密码存储与验证方法,它结合了密码哈希函数和加密算法。BCrypt 加密基于哈希函数,并使用一个密码和一个随机生成的盐值作为输入,生成一个固定长度的密码哈希值。这个哈希值在每次密码输入时都会重新生成,且会随着盐值的改变而改变。这种机制确保了即使是相同的密码,在每次加密时也会生成不同的哈希值,从而有效增强了安全性。Bcrypt 生成的密文是 60 位的,而 MD5 的是 32 位的。

BCrypt 不可以逆

http://www.lryc.cn/news/531755.html

相关文章:

  • 笔记:新能源汽车零部件功率级测试怎么进行?
  • ES6中的map和原生的对象有什么区别?
  • 2502vim,vim文本对象中文文档
  • spring security与gateway结合进行网关鉴权和授权
  • LabVIEW在电机自动化生产线中的实时数据采集与生产过程监控
  • log4j2日志配置文件
  • 用Deepseek做EXCLE文件对比
  • Tailwind CSS v4.0 升级与 Astro 5.2 项目迁移记录
  • TongSearch3.0.4.0安装和使用指引(by lqw)
  • 低代码产品表单渲染架构
  • windows 剪切板的写入、读取,包括图片,文本内容
  • Matplotlib 高级图表绘制与交互式可视化(mpld3)
  • (9)gdb 笔记(2):查看断点 info b,删除断点 delete 3,回溯 bt,
  • 专业学习|通过案例了解蒙特卡罗模拟实操步骤与含义
  • 云端智慧:创业公司如何以全球视野选择最佳平台,实现业务新高度
  • 【工具变量】中国省级八批自由贸易试验区设立及自贸区设立数据(2024-2009年)
  • 猫眼Java开发面试题及参考答案(上)
  • WSL2中安装的ubuntu开启与关闭探讨
  • Linux抢占式内核:技术演进与源码解析
  • 【Numpy核心编程攻略:Python数据处理、分析详解与科学计算】2.28 NumPy+Matplotlib:科学可视化的核心引擎
  • C#面试常考随笔12:游戏开发中常用的设计模式【C#面试题(中级篇)补充】
  • 【深度学习入门_机器学习理论】朴素贝叶斯(NaiveBayes)
  • docker pull Error response from daemon问题
  • javaEE-8.JVM(八股文系列)
  • 25.02.04 《CLR via C#》 笔记 13
  • git 项目的更新
  • 【Rust自学】17.3. 实现面向对象的设计模式
  • 51c视觉~CV~合集10
  • 如何安全地管理Spring Boot项目中的敏感配置信息
  • Docker小游戏 | 使用Docker部署2048网页小游戏