2023-09-19  阅读(2)
原文作者:墨家巨子@俏如来 原文地址: https://blog.csdn.net/u014494148/article/details/108269472

1.认证结果处理

1.1.认证成功处理

在传统的应用中,认证成功后页面需要跳转到认证成功页面或者跳转到个人中心页,但是在前后端分离的项目通常是使用Ajax请求完成认证,这时候我们需要返回一个JSON结果告知前端认证结果,然后前端自行跳转页面。

要做到上述功能,我们需要自定义认证成功处理器实现AuthenticationSuccessHandler接口复写 onAuthenticationSuccess方法,该方法其中一个参数是Authentication ,他里面封装了认证信息,用户信息UserDetails等,我们需要在这个方法中使用Response写出json数据即可

1.导入JSON依赖

    <dependency>
      <groupId>com.alibaba</groupId>
      <artifactId>fastjson</artifactId>
      <version>1.2.50</version>
    </dependency>

2.定义AuthenticationSuccessHandler

定义类实现AuthenticationSuccessHandler接口复写onAuthenticationSuccess方法,实现自己的认证成功结果处理

    public class MyAuthenticationSuccessHandler implements AuthenticationSuccessHandler {
        @Override
    	public void onAuthenticationSuccess(HttpServletRequest request, HttpServletResponse response, Authentication authentication) 
    throws IOException, ServletException {
            response.setContentType("application/json;charset=utf-8");
            Map map = new HashMap<>();
            map.put("success",true);
            map.put("message","认证成功");
            map.put("data",authentication);
            response.getWriter().print(JSON.toJSONString(map));
            response.getWriter().flush();
            response.getWriter().close();
        }
    }

3.配置AuthenticationSuccessHandler

在SpringSecurity配置定义的AuthenticationSuccessHandler

    http.formLogin()
    //.successForwardUrl("/loginSuccess") // 设置登陆成功页
    .successHandler(new MyAuthenticationSuccessHandler)
    ...

1.2.认证失败结果处理

自定义登录失败的处理,需要实现AuthenticationFailureHandler接口,复写onAuthenticationFailure方法实现自己的认证失败结果处理

1.定义认证失败处理器

    public class MyAuthenticationFailureHandler implements AuthenticationFailureHandler {
        @Override
        public void onAuthenticationFailure(HttpServletRequest request, HttpServletResponse response, AuthenticationException exception) throws IOException, ServletException {
    	    response.setContentType("application/json;charset=utf-8");
            Map map = new HashMap<>();
            map.put("success",false);
            map.put("message","认证失败");
            response.setStatus(HttpStatus.UNAUTHORIZED.value());
            response.getWriter().print(JSON.toJSONString(map));
            response.getWriter().flush();
            response.getWriter().close();
        }
    }

2.配置处理器

    http.formLogin()
    .failureHandler(new MyAuthenticationFailureHandler)
    ...

2.授权结果处理

1.授权失败处理

当用户请求资源服务的资源时,需要进行用户的认证和授权检查,当认证或授权检查失败,我们需要要返回自己的失败结果信息,可以通过HttpSecurity设置授权失败结果处理器,内部通过 ExceptionTranslationFilter 调用AuthenticationEntryPoint实现匿名用户授权失败结果处理, ExceptionTranslationFilter 通过 AccessDeniedHandler来处理授权失败结果处理。

1.定义认证检查失败处理

定义AccessDeineHandler 用来解决认证过的用户访问无权限资源时的异常

    public class DefaultAccessDeniedHandler implements AccessDeniedHandler {
    
        @Override
        public void handle(HttpServletRequest request, HttpServletResponse response, AccessDeniedException accessDeniedException) throws IOException, ServletException {
            String result = JSON.toJSONString(AjaxResult.me().setSuccess(false).setMessage("无访问权限"));
            response.setContentType("text/html;charset=utf-8");
            PrintWriter writer = response.getWriter();
            writer.print(result);
            writer.flush();
            writer.close();
        }
    }

2.定义AuthenticationEntryPoint

AuthenticationEntryPoint 用来解决匿名用户访问无权限资源时的异常

    
    public class MyAuthenticationEntryPoint implements AuthenticationEntryPoint {
        @Override
        public void commence(HttpServletRequest httpServletRequest, HttpServletResponse httpServletResponse, AuthenticationException e) throws IOException, ServletException {
            e.printStackTrace();
            httpServletResponse.setContentType("application/json;charset=utf-8");
            Map<String,Object> result = new HashMap<>();
            result.put("success",false);
            result.put("message","登录失败,用户名或密码错误["+e.getMessage()+"]");
            httpServletResponse.getWriter().print(JSONUtils.toJSONString(result));
        }
    }

3.配置异常处理器

配置异常处理器

    httpSecurity.exceptionHandling()
     .accessDeniedHandler(new DefaultAccessDeniedHandler ())
    .authenticationEntryPoint(new MyAuthenticationEntryPoint()) //身份认证验证失败配置

Java 面试宝典是大明哥全力打造的 Java 精品面试题,它是一份靠谱、强大、详细、经典的 Java 后端面试宝典。它不仅仅只是一道道面试题,而是一套完整的 Java 知识体系,一套你 Java 知识点的扫盲贴。

它的内容包括:

  • 大厂真题:Java 面试宝典里面的题目都是最近几年的高频的大厂面试真题。
  • 原创内容:Java 面试宝典内容全部都是大明哥原创,内容全面且通俗易懂,回答部分可以直接作为面试回答内容。
  • 持续更新:一次购买,永久有效。大明哥会持续更新 3+ 年,累计更新 1000+,宝典会不断迭代更新,保证最新、最全面。
  • 覆盖全面:本宝典累计更新 1000+,从 Java 入门到 Java 架构的高频面试题,实现 360° 全覆盖。
  • 不止面试:内容包含面试题解析、内容详解、知识扩展,它不仅仅只是一份面试题,更是一套完整的 Java 知识体系。
  • 宝典详情:https://www.yuque.com/chenssy/sike-java/xvlo920axlp7sf4k
  • 宝典总览:https://www.yuque.com/chenssy/sike-java/yogsehzntzgp4ly1
  • 宝典进展:https://www.yuque.com/chenssy/sike-java/en9ned7loo47z5aw

目前 Java 面试宝典累计更新 400+ 道,总字数 42w+。大明哥还在持续更新中,下图是大明哥在 2024-12 月份的更新情况:

想了解详情的小伙伴,扫描下面二维码加大明哥微信【daming091】咨询

同时,大明哥也整理一套目前市面最常见的热点面试题。微信搜[大明哥聊 Java]或扫描下方二维码关注大明哥的原创公众号[大明哥聊 Java] ,回复【面试题】 即可免费领取。

阅读全文