• Spring Security-自定义登录页面和认证过程其他常用配置


    一、自定义登录页面

    虽然Spring Security给我们提供了登录页面,但是对于实际项目中,大多喜欢使用自己的登录页面。所以Spring Security中不仅仅提供了登录页面,还支持用户自定义登录页面。实现过程也比较简单,只需要修改配置类即可。

    1.编写登录页面

    别写登录页面,登录页面中

    的action不编写对应控制器也可以。

    1. html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <title>内容title>
    6. head>
    7. <body>
    8. <form action="/login" method="post">
    9. <input type="text" name="username"/>
    10. <input type="password" name="password"/>
    11. <input type="submit" value="提交"/>
    12. form>
    13. body>
    14. html>
    15. 复制代码

    2.修改配置类

    ​ 修改配置类中主要是设置哪个页面是登录页面。配置类需要继承WebSecurityConfigurerAdapter,并重写configure方法。

    ​ successForwardUrl()登录成功后跳转地址

    ​ loginPage() 登录页面

    ​ loginProcessingUrl 登录页面表单提交地址,此地址可以不真实存在。

    ​ antMatchers():匹配内容

    ​ permitAll():允许

    1. @Configuration
    2. public class SecurityConfig extends WebSecurityConfigurerAdapter {
    3. @Override
    4. protected void configure(HttpSecurity http) throws Exception {
    5. // 表单认证
    6. http.formLogin()
    7. .loginProcessingUrl("/login")
    8. //当发现/login时认为是登录,需要执行
    9. UserDetailsServiceImpl
    10. .successForwardUrl("/toMain") //此处是post请求
    11. .loginPage("/login.html");
    12. // url 拦截
    13. http.authorizeRequests()
    14. .antMatchers("/login.html").permitAll() //login.html不需要被认证
    15. .anyRequest().authenticated();//所有的请求都必须被认证。必须登录后才能访问。
    16. //关闭csrf防护
    17. http.csrf().disable();
    18. }
    19. @Bean
    20. public PasswordEncoder getPe(){
    21. return new BCryptPasswordEncoder();
    22. }
    23. }
    24. 复制代码

    3.编写控制器

    编写控制器,当用户登录成功后跳转toMain控制器。编写完成控制器后编写main.html。页面中随意写上一句话表示main.html页面内容即可。而之前的/login控制器方法是不执行的,所以可以删除了。

    1. @Controller
    2. public class LoginController {
    3. // 该方法不会被执行
    4. // @RequestMapping("/login")
    5. // public String login(){
    6. // System.out.println("执行了login方法");
    7. // return "redirect:main.html";
    8. // }
    9. @PostMapping("/toMain")
    10. public String toMain(){
    11. return "redirect:/main.html";
    12. }
    13. }
    14. 复制代码

    二、 认证过程其他常用配置

    1.失败跳转

    表单处理中成功会跳转到一个地址,失败也可以跳转到一个地址中。

    1.1编写页面

    在src/main/resources/static下新建fail.html并编写如下内容

    1. html>
    2. <html lang="en">
    3. <head>
    4. <meta charset="UTF-8">
    5. <title>Titletitle>
    6. head>
    7. <body>
    8. 操作失败,请重新登录. <a href="/login.html">跳转a>
    9. body>
    10. html>
    11. 复制代码

    1.2修改表单配置

    在配置方法中表单认证部分添加failureForwardUrl()方法,表示登录失败跳转的url。此处依然是POST请求,所以跳转到可以接收POST请求的控制器/fail中。

    1. // 表单认证
    2. http.formLogin()
    3. .loginProcessingUrl("/login") //当发现/login时认为是登录,需要执行UserDetailsServiceImpl
    4. .successForwardUrl("/toMain") //此处是post请求
    5. .failureForwardUrl("/fail") //登录失败跳转地址
    6. .loginPage("/login.html");
    7. 复制代码

    1.3添加控制器方法

    在控制器类中添加控制器方法,方法映射路径/fail。此处要注意:由于是POST请求访问/fail。所以如果返回值直接转发到fail.html中,及时有效果,控制台也会报警告,提示fail.html不支持POST访问方式。

    1. @PostMapping("/fail")
    2. public String fail(){
    3. return "redirect:/fail.html";
    4. }
    5. 复制代码

    1.4设置fail.html不需要认证

    认证失败跳转到fail.html页面中,所以必须配置fail.html不需要被认证。需要修改配置类中内容

    1. // url 拦截
    2. http.authorizeRequests()
    3. .antMatchers("/login.html").permitAll() //login.html不需要被认证
    4. .antMatchers("/fail.html").permitAll() //fail.html不需要被认证
    5. .anyRequest().authenticated();//所有的请求都必须被认证。必须登录后才能访问。
    6. 复制代码

    2.设置请求账户和密码的参数名

    2.1源码简介

    当进行登录时会执行UsernamePasswordAuthenticationFilter过滤器。

    usernamePasrameter:账户参数名

    passwordParameter:密码参数名

    postOnly=true:默认情况下只允许POST请求。

    2.2修改配置

    1. // 表单认证
    2. http.formLogin()
    3. .loginProcessingUrl("/login") //当发现/login时认为是登录,需要执行UserDetailsServiceImpl
    4. .successForwardUrl("/toMain") //此处是post请求
    5. .failureForwardUrl("/fail") //登录失败跳转地址
    6. .loginPage("/login.html")
    7. .usernameParameter("myusername")
    8. .passwordParameter("mypassword");
    9. 复制代码

    2.3修改页面

    ​ 修改login.html

    1. <form action = "/login" method="post">
    2. 用户名:<input type="text" name="myusername"/><br/>
    3. 密码:<input type="password" name="mypassword"/><br/>
    4. <input type="submit" value="登录"/>
    5. form>
    6. 复制代码

    3.自定义登录成功处理器

    3.1源码分析

    使用successForwardUrl()时表示成功后转发请求到地址。内部是通过successHandler()方法进行控制成功后交给哪个类进行处理

    ForwardAuthenticationSuccessHandler内部就是最简单的请求转发。由于是请求转发,当遇到需要跳转到站外或在前后端分离的项目中就无法使用了。

    当需要控制登录成功后去做一些事情时,可以进行自定义认证成功控制器。

    3.2代码实现

    3.2.1自定义类

    新建类com.msb.handler.MyAuthenticationSuccessHandler编写如下:

    1. public class MyAuthenticationSuccessHandler implements AuthenticationSuccessHandler {
    2. @Override
    3. public void onAuthenticationSuccess(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, Authentication authentication) throws IOException, ServletException {
    4. //Principal 主体,存放了登录用户的信息
    5. User user = (User)authentication.getPrincipal();
    6. System.out.println(user.getUsername());
    7. System.out.println(user.getPassword());//密码输出为null
    8. System.out.println(user.getAuthorities());
    9. //重定向到百度。这只是一个示例,具体需要看项目业务需求
    10. httpServletResponse.sendRedirect("http://www.baidu.com");
    11. }
    12. }
    13. 复制代码

    3.2.2修改配置项

    使用successHandler()方法设置成功后交给哪个对象进行处理

    1. // 表单认证
    2. http.formLogin()
    3. .loginProcessingUrl("/login") //当发现/login时认为是登录,需要执行UserDetailsServiceImpl
    4. .successHandler(new MyAuthenticationSuccessHandler())
    5. //.successForwardUrl("/toMain") //此处是post请求
    6. .failureForwardUrl("/fail") //登录失败跳转地址
    7. .loginPage("/login.html");
    8. 复制代码

    4.自定义登录失败处理器

    4.1源码分析

    ForwardAuthenticationFailureHandler中也是一个请求转发,并在request作用域中设置 SPRING_SECURITY_LAST_EXCEPTION的key,内容为异常对象。

    4.2代码实现

    4.2.1新建控制器

    新建com.msb.handler.MyForwardAuthenticationFailureHandler实现AuthenticationFailureHandler。在方法中添加重定向语句

    1. public class MyForwardAuthenticationFailureHandler implements AuthenticationFailureHandler {
    2. @Override
    3. public void onAuthenticationFailure(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, AuthenticationException e) throws IOException, ServletException {
    4. httpServletResponse.sendRedirect("/fail.html");
    5. }
    6. }
    7. 复制代码

    4.2.2修改配置类

    ​ 修改配置类中表单登录部分。设置失败时交给失败处理器进行操作。failureForwardUrl和failureHandler不可共存。

    1. // 表单认证
    2. http.formLogin()
    3. .loginProcessingUrl("/login") //当发现/login时认为是登录,需要执行UserDetailsServiceImpl
    4. .successHandler(new MyAuthenticationSuccessHandler())
    5. //.successForwardUrl("/toMain") //此处是post请求
    6. .failureHandler(new MyForwardAuthenticationFailureHandler())
    7. // .failureForwardUrl("/fail") //登录失败跳转地址
    8. .loginPage("/login.html");


     

  • 相关阅读:
    多功能电力仪表在物联网的应用
    Android多线程学习:线程
    Win11查看电脑磁盘分区格式的方法教学
    第三讲 测量项目代码撰写1
    【技术积累】算法中的动态规划【二】
    Networkx绘图和常用库函数坐标绘图
    聊天页面样式
    002-JAVA的数据类型,变量声明与定义
    小区物业管理缴费报修活动报名商城小程序开源版开发
    最长公共子串 动态规划
  • 原文地址:https://blog.csdn.net/m0_71777195/article/details/126084949