springboot security使用

Spring Security是一个强大的认证和授权框架,它可以轻松帮助你实现各种安全功能,如身份验证、授权、会话管理、密码重置、OAuth等。

使用Spring Boot框架可以更快地构建和配置Spring Security。下面是在Spring Boot应用程序中使用Spring Security的基本步骤:

  1. 配置pom.xml文件添加Spring Security依赖:

    <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-security</artifactId> </dependency>
  2. 创建一个Security配置文件,例如:

    @Configuration
    @EnableWebSecurity
    public class SecurityConfig extends WebSecurityConfigurerAdapter {

    复制代码
     @Override
     protected void configure(HttpSecurity http) throws Exception {
         http
             .authorizeRequests()
                 .antMatchers("/", "/home").permitAll()
                 .anyRequest().authenticated()
                 .and()
             .formLogin()
                 .loginPage("/login")
                 .permitAll()
                 .and()
             .logout()
                 .permitAll();
     }
    
     @Autowired
     public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
         auth
             .inMemoryAuthentication()
                 .withUser("user").password("password").roles("USER");
     }

    }

  3. 创建用户详细信息。你可以创建一个用户详细信息类并实现UserDetails接口,也可以使用Spring Security提供的User类。例如:

    @Service
    public class UserService implements UserDetailsService {

    复制代码
     @Override
     public UserDetails loadUserByUsername(String username) throws UsernameNotFoundException {
         User user = new User("user", "password", 
           new ArrayList<GrantedAuthority>(Arrays.asList(new SimpleGrantedAuthority("USER"))));
         return user;
     }

    }

  4. 创建控制器和视图,例如:

    @Controller
    public class HomeController {

    复制代码
     @RequestMapping(value={"/", "/home"}, method=RequestMethod.GET)
     public String home(Model model) {
         model.addAttribute("message", "Welcome to the home page!");
         return "home";
     }
    
     @RequestMapping(value="/login", method=RequestMethod.GET)
     public String login(Model model) {
         return "login";
     }

    }

  5. 创建视图模板。可以使用Thymeleaf或其他模板引擎创建视图模板。

Spring Security提供了很多的配置选项,可以根据需要进行更改。在这个基本配置中,用户需要通过登录表单进行身份验证,然后才能访问任何受保护的资源。这个配置使用一个内存身份验证管理器,但你可以使用其他身份验证方式,例如LDAP或数据库。

相关推荐
wuqingshun3141597 分钟前
说说mybatis的缓存机制
java·缓存·mybatis
空中海33 分钟前
Kubernetes 生产实践、可观测性与扩展入门
java·贪心算法·kubernetes
Devin~Y1 小时前
大厂Java面试实录:Spring Boot/Cloud、Kafka、Redis、K8s 与 Spring AI(RAG/Agent)三轮连环问
java·spring boot·redis·mysql·spring cloud·kafka·kubernetes
bLEd RING1 小时前
SpringBoot3.3.0集成Knife4j4.5.0实战
java
小松加哲1 小时前
Spring MVC 核心原理全解析
java·spring·mvc
Ulyanov2 小时前
《PySide6 GUI开发指南:QML核心与实践》 第二篇:QML语法精要——构建声明式UI的基础
java·开发语言·javascript·python·ui·gui·雷达电子对抗系统仿真
码界筑梦坊2 小时前
357-基于Java的大型商场应急预案管理系统
java·开发语言·毕业设计·知识分享
云烟成雨TD2 小时前
Spring AI Alibaba 1.x 系列【31】集成 Studio 模块实现可视化 Agent 调试
java·人工智能·spring
014-code2 小时前
Spring Data JPA 实战指南
java·spring
安小牛2 小时前
Android 开发汉字转带声调的拼音
android·java·学习·android studio