Spring boot整合security详解

Spring Boot整合Security详解

Spring Security是一个功能强大的安全框架,可以帮助我们保护Web应用程序。Spring Boot提供了与Spring Security的无缝集成,本文将详细介绍如何使用Spring Boot整合Security,并提供两个示例。

添加依赖

首先,我们需要在pom.xml文件中添加Spring Security的依赖:

<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-security</artifactId>
</dependency>

配置Security

接下来,我们需要配置Security。在Spring Boot中,我们可以通过创建一个继承自WebSecurityConfigurerAdapter的配置类来配置Security。

@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.authorizeRequests()
            .antMatchers("/admin/**").hasRole("ADMIN")
            .antMatchers("/user/**").hasRole("USER")
            .anyRequest().authenticated()
            .and()
            .formLogin()
            .and()
            .logout()
            .logoutSuccessUrl("/");
    }

    @Autowired
    public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
        auth.inMemoryAuthentication()
            .withUser("admin").password("{noop}admin").roles("ADMIN")
            .and()
            .withUser("user").password("{noop}user").roles("USER");
    }
}

在上面的示例中,我们创建了一个名为SecurityConfig的配置类,并继承自WebSecurityConfigurerAdapter。在configure()方法中,我们配置了请求的权限和登录/注销的行为。在configureGlobal()方法中,我们配置了用户的认证信息。

示例一:基于内存的认证

以下是一个示例,演示如何使用基于内存的认证:

@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.authorizeRequests()
            .antMatchers("/admin/**").hasRole("ADMIN")
            .antMatchers("/user/**").hasRole("USER")
            .anyRequest().authenticated()
            .and()
            .formLogin()
            .and()
            .logout()
            .logoutSuccessUrl("/");
    }

    @Autowired
    public void configureGlobal(AuthenticationManagerBuilder auth) throws Exception {
        auth.inMemoryAuthentication()
            .withUser("admin").password("{noop}admin").roles("ADMIN")
            .and()
            .withUser("user").password("{noop}user").roles("USER");
    }
}

在上面的示例中,我们使用了基于内存的认证。在configureGlobal()方法中,我们使用auth.inMemoryAuthentication()方法配置了两个用户的认证信息。

示例二:基于数据库的认证

以下是一个示例,演示如何使用基于数据库的认证:

  1. 创建一个名为User的实体类,用于表示用户信息:
@Entity
@Table(name = "users")
public class User {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(nullable = false, unique = true)
    private String username;

    @Column(nullable = false)
    private String password;

    @Column(nullable = false)
    private boolean enabled;

    @ManyToMany(fetch = FetchType.EAGER)
    @JoinTable(
        name = "user_roles",
        joinColumns = @JoinColumn(name = "user_id"),
        inverseJoinColumns = @JoinColumn(name = "role_id")
    )
    private Set<Role> roles = new HashSet<>();

    // getters and setters
}

在上面的示例中,我们创建了一个名为User的实体类,并使用JPA注解配置了实体类与数据库表的映射关系。

  1. 创建一个名为Role的实体类,用于表示角色信息:
@Entity
@Table(name = "roles")
public class Role {
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Long id;

    @Column(nullable = false, unique = true)
    private String name;

    @ManyToMany(mappedBy = "roles")
    private Set<User> users = new HashSet<>();

    // getters and setters
}

在上面的示例中,我们创建了一个名为Role的实体类,并使用JPA注解配置了实体类与数据库表的映射关系。

  1. 创建一个名为UserRepository的接口,用于操作用户信息:
@Repository
public interface UserRepository extends JpaRepository<User, Long> {
    User findByUsername(String username);
}

在上面的示例中,我们创建了一个名为UserRepository的接口,并继承自JpaRepository。在接口中,我们定义了一个findByUsername()方法,用于根据用户名查询用户信息。

  1. 创建一个名为SecurityConfig的配置类,用于配置Security:
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
    @Autowired
    private UserRepository userRepository;

    @Override
    protected void configure(HttpSecurity http) throws Exception {
        http.authorizeRequests()
            .antMatchers("/admin/**").hasRole("ADMIN")
            .antMatchers("/user/**").hasRole("USER")
            .anyRequest().authenticated()
            .and()
            .formLogin()
            .and()
            .logout()
            .logoutSuccessUrl("/");
    }

    @Override
    protected void configure(AuthenticationManagerBuilder auth) throws Exception {
        auth.userDetailsService(username -> {
            User user = userRepository.findByUsername(username);
            if (user != null) {
                return new org.springframework.security.core.userdetails.User(
                    user.getUsername(),
                    user.getPassword(),
                    user.isEnabled(),
                    true,
                    true,
                    true,
                    user.getRoles().stream().map(role -> new SimpleGrantedAuthority(role.getName())).collect(Collectors.toList())
                );
            } else {
                throw new UsernameNotFoundException("User not found");
            }
        });
    }
}

在上面的示例中,我们创建了一个名为SecurityConfig的配置类,并继承自WebSecurityConfigurerAdapter。在configure()方法中,我们配置了请求的权限和登录/注销的行为。在configure()方法中,我们使用auth.userDetailsService()方法配置了用户的认证信息。

总结

在本文中,我们介绍了如何使用Spring Boot整合Security,并提供了两个示例。这些技巧可以帮助您更好地理解Spring Boot中如何实现安全认证,并提高开发效率。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:Spring boot整合security详解 - Python技术站

(0)
上一篇 2023年5月15日
下一篇 2023年5月15日

相关文章

  • Java中的NullPointerException如何避免?

    Java中的NullPointerException(空指针异常)是一种常见的运行时异常,在处理对象时,如果操作了空对象,就有可能出现NullPointerException,导致程序崩溃。为了避免NullPointerException出现,我们需要注意以下几点: 1. 空指针判断 在操作可能会出现空指针异常的对象之前,要进行空指针判断以避免程序崩溃。可以…

    Java 2023年4月27日
    00
  • Java中Thread类的使用和它的属性

    一、Thread类的使用 在Java中,多线程的实现主要通过Thread类来完成。通过继承Thread类并重写run()方法来实现多线程的功能。 具体步骤如下: 1.定义Thread类的子类,并重写其run()方法 2.在run()方法中编写并发执行的代码。 3.调用Thread类中的start()方法,就可以启动线程。 举个例子,如下所示: public …

    Java 2023年5月19日
    00
  • java实现简易超市管理系统 附源码下载

    Java实现简易超市管理系统攻略 实现思路 本超市管理系统的主要功能包括如下: 实现商品的库存管理功能,包括商品的入库、出库和查询等操作。 实现商品的销售管理功能,包括购物车、结算和打印小票等操作。 实现系统的用户管理功能,包括用户登录和登出、用户信息修改等操作。 根据上述需求,我们可以把整个系统分成三大模块:商品管理模块、销售管理模块和用户管理模块。每个模…

    Java 2023年5月18日
    00
  • Java集合框架概览之ArrayList源码刨析

    Java集合框架概览之ArrayList源码刨析是一个非常重要的主题,需要我们详细探讨ArrayList源码实现的细节,以下为详细攻略: 了解ArrayList基本使用和源码实现 ArrayList基本使用 ArrayList是一个基于动态数组实现的集合类,并且实现了List接口,可以重复存储相同类型的数据。ArrayList也是Java集合框架中基础的数据…

    Java 2023年5月26日
    00
  • Java异常体系非正常停止和分类

    Java 异常体系是指在执行 Java 程序时所发生的异常情况。Java 程序在运行时可能会遇到各种各样的异常情况,比如空指针异常、数组下标越界异常、文件不存在异常等。这些异常情况可能会导致程序出现非正常停止的情况,因此了解 Java 异常体系非常重要。 Java 异常体系的分类 Java 异常体系分为两大类:可检查异常和不可检查异常。 可检查异常是指那些在…

    Java 2023年5月27日
    00
  • AndroidStudio4.1 自定义模板的使用方法

    AndroidStudio4.1 自定义模板的使用方法 简介 在开发 Android 应用过程中,我们经常需要创建大量的 Activity、Fragment、Adapter、ViewModel 等等。而每次新建这些文件都需要手动创建,费时费力,容易出错。Android Studio 就提供了模板功能,支持快速生成各种文件模板。在 Android Studio…

    Java 2023年6月1日
    00
  • win10环境下 VMware Workstation Pro 安装centos7无法上网

    一、安装centos7 网上类似的教程太多了,我就不一一写了,提供两个网址,先按照教程安装 VMware Workstation Pro ,秘钥在第二个链接里面(亲测可用), 安装完VMware在根据教程安装centos7,网络配置安装教程中不全,可参考如下 虚拟机安装教程  VMware Workstation Pro激活秘钥 二、配置网络 一、点击菜单栏…

    Java 2023年4月22日
    00
  • 通过实例深入学习Java的Struts框架中的OGNL表达式使用

    让我来详细讲解一下“通过实例深入学习Java的Struts框架中的OGNL表达式使用”的完整攻略。 什么是Struts框架中的OGNL表达式? OGNL 表达式是 Object-Graph Navigation Language (对象图导航语言)的缩写,是在Struts框架中用于处理表达式语言的一种语言。通过OGNL表达式,我们可以访问对象的属性、方法和集…

    Java 2023年5月20日
    00
合作推广
合作推广
分享本页
返回顶部