zoukankan      html  css  js  c++  java
  • 【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"));
        }
    }
  • 相关阅读:
    SQL Server数据库中批量导入数据
    SQL里面也能用Split()
    MSSQL发送邮件
    Asp.Net简单的发邮件功能
    十大措施保证系统安全性
    WebDriver测试web中遇到的弹出框或不确定的页面
    WebDriver数据驱动模式
    nginx 优化(转)
    配置虚拟目录出错
    14152学期校内岗招聘信息
  • 原文地址:https://www.cnblogs.com/justbeginning/p/14792902.html
Copyright © 2011-2022 走看看