当前位置 主页 > 网站技术 > 代码类 >

    SpringSecurity 自定义表单登录的实现

    栏目:代码类 时间:2020-01-24 15:06

    本篇主要讲解 在SpringSecurity中 如何 自定义表单登录 , SpringSecurity默认提供了一个表单登录,但是实际项目里肯定无法使用的,本篇就主要讲解如何自定义表单登录

    1.创建SpringSecurity项目

    1.1 使用IDEA

    先通过IDEA 创建一个SpringBoot项目 并且依赖SpringSecurity,Web依赖

    此时pom.xml会自动添加

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

    2.扩展 WebSecurityConfigurerAdapter

    WebSecurityConfigurerAdapter 是SpringSecurity 提供的用于我们扩展自己的配置

     实现WebSecurityConfigurerAdapter经常需要重写的:

    1、configure(AuthenticationManagerBuilder auth);

    2、configure(WebSecurity web);

    3、configure(HttpSecurity http);

    2.1 默认 WebSecurityConfigurerAdapter 为我们提供了一些基础配置如下

    protected void configure(HttpSecurity http) throws Exception {
      logger.debug("Using default configure(HttpSecurity). If subclassed this will potentially override subclass configure(HttpSecurity).");
    
      http
        .authorizeRequests()
          .anyRequest().authenticated()
          .and()
        .formLogin().and()
        .httpBasic();
    }
    
    

    2.2 创建自定义的 WebSecurityConfigurer

    1.formLogin() 开启表单登录,该方法会应用 FormLoginConfigurer 到HttpSecurity上,后续会被转换为对应的Filter
    2.loginPage() 配置自定义的表单页面
    3.authorizeRequests().anyRequest().authenticated(); 表示任何请求接口都要认证**

    @Configuration
    @Slf4j
    public class MyWebSecurityConfig extends WebSecurityConfigurerAdapter {
    
     
    
    @Override
    protected void configure(HttpSecurity http) throws Exception {
    
        http.csrf().disable()
          .formLogin()
          .loginPage("/mylogin.html")
          .and()
          .authorizeRequests().anyRequest().authenticated();
          
      }
    }  
    
    

    2.3 mylogin.html

    <!DOCTYPE html>
    <html lang="en">
     <head>
       <meta charset="UTF-8">
       <title>Title</title>
     </head>
     <body>
      <h1>标准登录页面</h1>
      <h3>表单登录</h3>
    
     <form action="/login" method="post">
      <table>
      <tr>
        <td>用户名:</td>
        <td><input type="text" name="username"/></td>
      </tr>
    
      <tr>
        <td>密码:</td>
        <td><input type="password" name="password"/></td>
      </tr>
    
      <tr>
        <td colspan="2">
          <button type="submit">登录</button>
        </td>
      </tr>
      </table>
     </form>
    </body>
    </html>

    3.访问自定义登录页面(注意有重定向过多问题)

    启动项目 并且直接访问

    http://localhost:8080