1500字范文,内容丰富有趣,写作好帮手!
1500字范文 > Spring Security入门(三):密码加密

Spring Security入门(三):密码加密

时间:2023-05-27 17:53:02

相关推荐

Spring Security入门(三):密码加密

前文导读

-Spring Security入门(一):登录与退出

-Spring Security入门(二):基于数据库验证

Github 地址

/ChinaSilence/any-spring-security 本文对应 security-login-db-encryptPWD

摘要

解决2个问题:

注册时密码加密后存入数据库

登录时密码加密校验

运行程序

1、clone 代码

git clone /ChinaSilence/any-spring-security.git

2、启动应用

mvn spring-boot:run

3、登录(使用账号 anoy 密码 pwd,未使用密码加密前是可以登录的)

控制台会出现如下提示:

Encoded password does not look like BCrypt

4、注册新账号并登录。

相关解释说明

相比于上一个demo,在WebSecurityConfig中添加了如下代码:

/**

* 添加 UserDetailsService, 实现自定义登录校验

*/

@Override

protected void configure(AuthenticationManagerBuilder builder) throws Exception{

builder.userDetailsService(anyUserDetailsService)

.passwordEncoder(passwordEncoder());

}

/**

* 密码加密

*/

@Bean

public BCryptPasswordEncoder passwordEncoder(){

return new BCryptPasswordEncoder();

}

BCryptPasswordEncoder相关知识:

用户表的密码通常使用MD5等不可逆算法加密后存储,为防止彩虹表破解更会先使用一个特定的字符串(如域名)加密,然后再使用一个随机的salt(盐值)加密。

特定字符串是程序代码中固定的,salt是每个密码单独随机,一般给用户表加一个字段单独存储,比较麻烦。

BCrypt算法将salt随机并混入最终加密后的密码,验证时也无需单独提供之前的salt,从而无需单独处理salt问题。

BCryptPasswordEncoder 是在哪里使用的?

登录时用到了DaoAuthenticationProvider,它有一个方法#additionalAuthenticationChecks(UserDetails userDetails,UsernamePasswordAuthenticationTokenauthentication),此方法用来校验从数据库取得的用户信息和用户输入的信息是否匹配。

在注册时,对用户密码加密

应用BCryptPasswordEncoder之后,明文密码是无法被识别的,就会校验失败,只有存入密文密码才能被正常识别。所以,应该在注册时对用户密码进行加密。

/**

* 加密密码

*/

private void encryptPassword(UserEntity userEntity){

String password = userEntity.getPassword();

password = new BCryptPasswordEncoder().encode(password);

userEntity.setPassword(password);

}

新用户注册后,数据库中就会存入密文密码,示例:

补充说明:即使不同的用户注册时输入相同的密码,存入数据库的密文密码也会不同。

推荐阅读

Netflix 的上线工具 Spinnaker

Dubbo将积极适配Spring Cloud生态

Spring Cloud微服务架构汇总

浅谈微服务基建的逻辑

Service Mesh:下一代微服务

微服务(Microservices)【翻译】

那些没说出口的研发之痛,做与不做微服务的几大理由

谷歌大神为你解释Kubernetes, 微服务和容器化

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。