• 【SpringBoot】安全漏洞处理


    对漏扫结果修复后,胡乱记一些

    一、容器

    @Configuration
    public class TomcatContainerConfig {
        
        @Bean
        public ConfigurableServletWebServerFactory servletContainer() {
            TomcatServletWebServerFactory tomcatServletContainerFactory = new TomcatServletWebServerFactory() {
                @Override
                protected void postProcessContext(Context context) {
                    SecurityConstraint constraint = new SecurityConstraint();
                    constraint.setUserConstraint("CONFIDENTIAL");
                    SecurityCollection collection = new SecurityCollection();
                    collection.addPattern("/*");
                    collection.addMethod("HEAD");
                    collection.addMethod("PUT");
                    collection.addMethod("PATCH");
                    collection.addMethod("DELETE");
                    collection.addMethod("OPTIONS");
                    collection.addMethod("TRACE");
                    collection.addMethod("COPY");
                    collection.addMethod("SEARCH");
                    collection.addMethod("PROPFIND");
                    constraint.addCollection(collection);
                    context.addConstraint(constraint);
                }
            };
            return tomcatServletContainerFactory;
        }
    }

    二、请求

    引入 Spring-Security组件 

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

    代码中增加配置

    @Configuration
    public class WebSecurityConfig extends WebSecurityConfigurerAdapter{
        
        @Override
        protected void configure(HttpSecurity http) throws Exception {
            http.authorizeRequests()
                    .antMatchers("/actuator").denyAll()
                    .antMatchers("/actuator/**").denyAll()
                    .antMatchers("/**").permitAll();
            http.csrf().disable();
            http.headers().frameOptions().sameOrigin();
            http.headers().referrerPolicy(ReferrerPolicyHeaderWriter.ReferrerPolicy.SAME_ORIGIN);
            http.headers().contentSecurityPolicy("default-src 'self'");
            http.headers().xssProtection();
            http.headers().contentTypeOptions();
            http.headers().addHeaderWriter(new StaticHeadersWriter("X-Download-Options","noopen"));
            http.headers().addHeaderWriter(new StaticHeadersWriter("X-Permitted-Cross-Domain-Policies","by-ftp-filename"));
        }
    }
  • 相关阅读:
    Ubuntu 开发环境
    机器学习笔记-相似度
    ElasticSearch 笔记-分布式工作原理
    ElasticSearch 笔记-别名
    ElasticSearch 笔记-映射
    ElasticSearch 笔记-基本概念
    Linux 二 常用命令
    经典中的经典算法:动态规划(详细解释,从入门到实践,逐步讲解)
    图解Transformer
    CUDA9.0+tensorflow-gpu1.8.0+Python2.7服务器环境搭建经验
  • 原文地址:https://www.cnblogs.com/justbeginning/p/14792902.html
Copyright © 2020-2023  润新知