Spring Security 提供了多种密码加密算法,用于在存储用户密码时进行加密,以增强安全性。
查看org.springframework.security.crypto.factory.PasswordEncoderFactories
以下是一些常用的密码加密算法:
-
BCryptPasswordEncoder:
-
这是Spring Security推荐使用的密码加密算法。
-
BCrypt算法每次生成的加密结果都是不同的,即使密码相同,因为每次加密时都会加入一个随机生成的盐值。
-
它使用10次循环(默认值,可以通过
strength
参数调整)来增加破解难度。
-
-
SHA-256/SHA-512PasswordEncoder:
-
这些是基于SHA-256或SHA-512哈希算法的密码加密器。
-
它们通常与盐值一起使用,以增加安全性。
-
-
StandardPasswordEncoder:
-
这是基于SHA-256的加密器,它使用一个固定的盐值。
-
由于它使用固定的盐值,因此不如BCryptPasswordEncoder安全。
-
-
Pbkdf2PasswordEncoder: