请教一个 Spring Boot 的 Security 的问题

2018-11-25 00:49:59 +08:00
 hengo

最近项目用的是 Spring Boot 使用了 Security 的 BCryptPasswordEncoder()方法加密密码。 这个是一个动态加盐的方法。 导致注册时我现在用这个方法加密后,存进数据库的密文对比登录时输入明文密码(用这个方法加密),新加密的密文和数据库里面的密文不一致,导致登录失败。 我不知道怎么关联注册时用的盐,求大神解答。 PS:我用 MD5 加密时,登录正常。

1920 次点击
所在节点    Java
4 条回复
CFO
2018-11-25 01:08:41 +08:00
我记得这个算法相同字符串每次加密生成的结果都是不一样的 所以要用 encoder 里面的一个比较方法来比对 参数是加密前的数据和加密后的数据
jakes
2018-11-25 01:11:48 +08:00
楼上正解,是要用专门的校验方法验证的,不是再次生成密码比对。
acrisliu
2018-11-25 01:15:46 +08:00
用自带的 matches 方法。
hengo
2018-11-25 02:04:37 +08:00
@jakes @acrisliu @CFO 感谢提示!用 matches 做出来了。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/511216

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX