springboot使用undertow服务器禁用TRACE请求
创始人
2025-01-20 00:33:13
0

问题描述:

今日在工作中遇到服务器被扫描出一个漏洞,描述如下:
风险描述:远程 Web 服务器支持 TRACE 和/或 TRACK方法。TRACE和 TRACK 是用于调试 Web 服务器连接的 HTTP 方法。
风险影响:通过一个跨站追踪攻击窃职 cookies 和验证信任

使用框架

springboot + redis +mybatis
web服务使用springboot 内嵌web服务 undertow
配置如下:

                               org.springframework.boot             spring-boot-starter-web                                                      spring-boot-starter-tomcat                      org.springframework.boot                                                                        org.springframework.boot             spring-boot-starter-undertow                      io.undertow         undertow-servlet           

在网上找啊找啊,大多是tomcat的,终于找到一个

@Bean public UndertowEmbeddedServletContainerFactory embeddedServletContainerFactory() {     UndertowEmbeddedServletContainerFactory factory = new UndertowEmbeddedServletContainerFactory();     factory.addBuilderCustomizers(new UndertowBuilderCustomizer() {          @Override         public void customize(Builder builder) {             builder.addHttpListener(8080, "0.0.0.0");         }      });     return factory; }  

很遗憾不能用,各种类找不到BUG,接续找,终于找到springboot 2.0之后类名字变更,所以修改如下:

package com.ruoyi.medicine.config;  import io.undertow.servlet.api.DeploymentInfo; import io.undertow.servlet.api.SecurityConstraint; import io.undertow.servlet.api.WebResourceCollection; import org.springframework.boot.web.embedded.undertow.UndertowDeploymentInfoCustomizer; import org.springframework.boot.web.embedded.undertow.UndertowServletWebServerFactory; import org.springframework.boot.web.server.WebServerFactory; import org.springframework.boot.web.server.WebServerFactoryCustomizer; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.http.HttpMethod;  /**  * @author wang'hai'yang  * @Description:  * @date 2024/2/2110:46  */ @Configuration public class EmbeddedServletContainerCustomizerConfig {      @Bean     public WebServerFactoryCustomizer containerCustomizer() {         return new WebServerFactoryCustomizer() {             @Override             public void customize(WebServerFactory factory) {                 if(factory.getClass().isAssignableFrom(UndertowServletWebServerFactory.class)){                     UndertowServletWebServerFactory underTowContainer = (UndertowServletWebServerFactory) factory;                     underTowContainer.addDeploymentInfoCustomizers(new ContextSecurityCustomizer());                 }             }         };     }      private static class ContextSecurityCustomizer implements UndertowDeploymentInfoCustomizer {         @Override         public void customize(DeploymentInfo deploymentInfo) {             SecurityConstraint constraint = new SecurityConstraint();             WebResourceCollection traceWebresource = new WebResourceCollection();             traceWebresource.addUrlPattern("/*");             traceWebresource.addHttpMethod(HttpMethod.TRACE.toString());             constraint.addWebResourceCollection(traceWebresource);             deploymentInfo.addSecurityConstraint(constraint);         }     } }  

测试方式及结果

在这里插入图片描述
如图所示,代表成功,否则 红框所示地方显示 HTTP/1.1 200 OK

相关内容

热门资讯

aapoker外挂!aapok... aapoker外挂!aapoker插件,(AAPOkER)真是是真的有挂(详细辅助曝光教程)aapo...
透视工具(WEPOKE)透明挂... 透视工具(WEPOKE)透明挂辅助app(WePoKe外挂)原本真的是有挂(详细透视黑科技教程),支...
aapoker辅助!aapok... aapoker辅助!aapoke辅助工具存在吗,(AaPOKER)真是是真的有挂(详细辅助解密教程)...
aapoker外挂!aapok... aapoker外挂!aapoker是谁开发的,(AAPoKER)果然存在有挂(详细辅助力荐教程)aa...
透视模拟器(来玩德州app)智... 透视模拟器(来玩德州app)智星德州菠萝有挂吗(透视)竟然存在有挂(详细辅助揭秘攻略)1、上手简单,...
aapoker猫腻!aa扑克发... aapoker猫腻!aa扑克发牌机制,(aa poker)一直有挂(详细辅助软件教程)1、aapok...
透视辅助(wEPoke)外挂透... 透视辅助(wEPoke)外挂透明挂辅助代打(wepoke辅助德之星)总是存在有挂(详细透视2025新...
透视脚本(智星德州)德扑之星a... 透视脚本(智星德州)德扑之星ai代打(透视)确实存在有挂(详细辅助揭秘教程)暗藏猫腻,小编详细说明德...
aapoker辅助!aapok... aapoker辅助!aapoker线上规律,(aaPoker)竟然是有挂(详细辅助力荐教程)1、起透...
透视科技(wePOke)透明挂... 透视科技(wePOke)透明挂辅助代打(wepokeai辅助)从来真的有挂(详细透视大神讲解);支持...