zoukankan      html  css  js  c++  java
  • Springsecurity源码Filter之HeaderWriterFilter(十二)

    提供我们在Filter链 执行之前或者之后往Header写入内容

    通过HttpSecurity  可以指定 默认是在之后调用

     http.headers().addHeaderWriter()

    通过org.springframework.security.config.annotation.web.configurers.HeadersConfigurer 初始化

    默认初始化处参考https://www.cnblogs.com/LQBlog/p/15508248.html#autoid-12-0-0

    private void applyDefaultConfiguration(HttpSecurity http) throws Exception {
            //http本质也是build 这里都是配置默认的config configure add CsrfConfigurer
            http.csrf();
            //默认增加一个WebAsyncManagerIntegrationFilter
            http.addFilter(new WebAsyncManagerIntegrationFilter());
            //configures add ExceptionHandlingConfigurer
            http.exceptionHandling();
            //configures add HeadersConfigurer
            http.headers();
            //configures add SessionManagementConfigurer
            http.sessionManagement();
            //configure add SecurityContextConfigurer
            http.securityContext();
            //configure add RequestCacheConfigurer
            http.requestCache();
            ///configure add AnonymousConfigurer
            http.anonymous();
            ///configure add ServletApiConfigurer
            http.servletApi();
            //configure DefaultLoginPageConfigurer
            http.apply(new DefaultLoginPageConfigurer<>());
            //configure LogoutConfigurer
            http.logout();
        }

    <1>

    org.springframework.security.web.header.HeaderWriterFilter#doFilterInternal

       @Override
        protected void doFilterInternal(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
                throws ServletException, IOException {
            //在Filter链执行之前执行 默认是false 不建议直接修改,如果有需求可以自定在定义一个HeaderFilter 因为默认的有许多默认Writer需要在之后执行
            if (this.shouldWriteHeadersEagerly) {
    //<2> doHeadersBefore(request, response, filterChain); }
    else { //<4>在Filter链条执行之后 doHeadersAfter(request, response, filterChain); } }

    <2>

    org.springframework.security.web.header.HeaderWriterFilter#doHeadersBefore

      private void doHeadersBefore(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
                throws IOException, ServletException {
            //<3>用我们的HeaderWriters
            writeHeaders(request, response);
            //执行调用链
            filterChain.doFilter(request, response);
        }

    <3>

    org.springframework.security.web.header.HeaderWriterFilter#writeHeaders

      void writeHeaders(HttpServletRequest request, HttpServletResponse response) {
            //调用HeaderWriters 我们可以动态指定 扩展点
            for (HeaderWriter writer : this.headerWriters) {
                writer.writeHeaders(request, response);
            }
        }

    <4>

    org.springframework.security.web.header.HeaderWriterFilter#doHeadersAfter

     private void doHeadersAfter(HttpServletRequest request, HttpServletResponse response, FilterChain filterChain)
                throws IOException, ServletException {
            //通过HeaderWriterResponse和HeaderWriterRequest 装饰 内部类 应该是为了发生异常或者重定向 调用WriteHeader
            HeaderWriterResponse headerWriterResponse = new HeaderWriterResponse(request, response);
            HeaderWriterRequest headerWriterRequest = new HeaderWriterRequest(request, headerWriterResponse);
            try {
                filterChain.doFilter(headerWriterRequest, headerWriterResponse);
            }
            finally {
                //<5>调用writeHeader
                headerWriterResponse.writeHeaders();
            }
        }

    <5>

    org.springframework.security.web.header.HeaderWriterFilter.HeaderWriterResponse#writeHeaders

     protected void writeHeaders() {
            //如果触发了Wapper的writeHeaders 则不再触发 避免重复调用
            if (isDisableOnResponseCommitted()) {
                return;
            }
    //<2> HeaderWriterFilter.
    this.writeHeaders(this.request, getHttpResponse()); }
  • 相关阅读:
    Selenium2+python自动化55-unittest之装饰器(@classmethod)【转载】
    Selenium2+python自动化54-unittest生成测试报告(HTMLTestRunner)【转载】
    验证码在登录页面的使用
    习课省市区的三级联动(cxselect的使用)
    jira的使用
    springmvc 用拦截器+token防止重复提交
    springMVC发送邮件
    Commons-Collections 集合工具类的使用
    习课的视频播放器 video.js
    习课的redis配置记录
  • 原文地址:https://www.cnblogs.com/LQBlog/p/15532360.html
Copyright © 2011-2022 走看看