栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

03-spring boot 2.6.2 spring security 基于配置类设计用户名和密码

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

03-spring boot 2.6.2 spring security 基于配置类设计用户名和密码

03-spring boot 2.6.2 spring security 基于配置类设计用户名和密码

更多关注:JeeGit 5.0 企业级快速开发平台

通过这种方式配置之后,上一集的配置类则无效了。

这里面涉及向内存中追加用户并配置密码策略。

我采用的是直接配置密码策略,有些人也会采用其他的密码策略。

NoOpPasswordEncoder 过时废弃的无密码策略 写方一
package com.godzt.jeegit.web.config;

import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.crypto.password.NoOpPasswordEncoder;


@Configuration
public class SpringSecurityConfig extends WebSecurityConfigurerAdapter{
	
	@Override
	protected void configure(AuthenticationManagerBuilder auth) throws Exception {
		// TODO Auto-generated method stub
		// super.configure(auth);
		auth.inMemoryAuthentication().passwordEncoder(NoOpPasswordEncoder.getInstance()).withUser("admin").password("admin").roles("admin");
		auth.inMemoryAuthentication().passwordEncoder(NoOpPasswordEncoder.getInstance()).withUser("jeegit").password("admin").roles("admin");
	}

	
	
	
	
}

默认缺省的BCryptPasswordEncoder 策略

这个 大家要知道,密码加密 解密的算法有很多中,具体想看自己到底有多少种密码加密策略,可以利用ctrl+t ,查看 PasswordEncoder 接口的实现类。

package com.godzt.jeegit.web.config;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.authentication.builders.AuthenticationManagerBuilder;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.crypto.bcrypt.BCryptPasswordEncoder;
import org.springframework.security.crypto.password.PasswordEncoder;

@Configuration
public class SpringSecurityConfig extends WebSecurityConfigurerAdapter{
	@Override
	protected void configure(AuthenticationManagerBuilder auth) throws Exception {
		// TODO Auto-generated method stub
		// super.configure(auth);
		BCryptPasswordEncoder  bCryptPasswordEncoder=new BCryptPasswordEncoder();
		auth.inMemoryAuthentication().withUser("admin").password(bCryptPasswordEncoder.encode("admin")).roles("admin");
		auth.inMemoryAuthentication().withUser("jeegit").password(bCryptPasswordEncoder.encode("admin")).roles("admin");
	}
	@Bean
	PasswordEncoder password() {
		return new BCryptPasswordEncoder();
	}
}

更多关注:JeeGit 5.0 企业级快速开发平台

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/704869.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号