漏洞:不安全的http请求方法,tomcat 禁用http method。代码解决

4 篇文章 0 订阅
3 篇文章 0 订阅

问题描述:通过fiddler,使用raw重现HTTP请求,修改GET为TRACE重新请求。tomcat返回405,head 包含

Allow:POST,GET,DELETE,OPTIONS,PUT,HEAD

解决方法:使用filter进行过滤和处理。

1.修改tomcat的server.xml,允许trace方法:<Connector allowTrace="true"

 

2.修改web.xml,添加filter

  <filter>
    <filter-name>filterUtil</filter-name>
    <filter-class>com.utils.FilterUtil</filter-class>
  </filter>
  <filter-mapping>
    <filter-name>filterUtil</filter-name>
    <url-pattern>/*</url-pattern>
  </filter-mapping>

 

 

3.添加filter类

package com.utils;

import java.io.IOException;

import javax.servlet.Filter;
import javax.servlet.FilterChain;
import javax.servlet.FilterConfig;
import javax.servlet.ServletException;
import javax.servlet.ServletRequest;
import javax.servlet.ServletResponse;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;

import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public class FilterUtil implements Filter {
	Logger log=LoggerFactory.getLogger(this.getClass());
	
	@Override
	public void destroy() {
		
	}

	@Override
	public void doFilter(ServletRequest arg0, ServletResponse arg1, FilterChain arg2)
			throws IOException, ServletException {
	    HttpServletRequest request = (HttpServletRequest) arg0;
	    HttpServletResponse response = ((HttpServletResponse) arg1); 
		String m=request.getMethod();
		if(!"GET".equals(m)&&!"POST".equals(m)){
			System.out.println("GET or POST only  ");
			response.setHeader("Allow", "GET,POST");
			response.setStatus(405);
			return;
		}
		arg2.doFilter(arg0, arg1);
	}

	@Override
	public void init(FilterConfig arg0) throws ServletException {
	}
	
}

 按错误的method请求即可看到效果:

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: TomcatHTTP状态404表示请求的资源未找到。解决方法可能包括以下几个方面: 1. 检查URL是否正确,确保请求的资源存在于服务器上。 2. 检查Tomcat的配置文件,确保应用程序的上下文路径和URL匹配。 3. 检查应用程序的部署路径,确保资源存在于正确的位置。 4. 检查Tomcat的日志文件,查看是否有任何错误或异常信息。 5. 重新启动Tomcat服务器,有时候这可以解决问题。 6. 如果以上方法都无法解决问题,可以尝试重新部署应用程序或重新安装Tomcat服务器。 ### 回答2: Tomcat是一个流行的Java Web服务器,在服务器处理网页请求时,经常会发生404错误,这是因为服务器无法找到所请求的资源。以下是解决这个问题的一些方法: 1. 检查URL是否正确。首先,您应该检查您输入的URL是否正确,因为如果URL拼写不正确,服务器将无法找到该资源。确保使用正确的大小写和正确的文件扩展名。 2. 检查文件路径。如果您确定URL是正确的,那么您应该检查该文件是否真的存在于服务器上。在Tomcat服务器上,您应该检查文件是否位于正确的文件路径中。 3. 检查文件权限。如果文件路径正确,则可能是因为权限问题而无法访问文件。您可以尝试更改文件的权限以允许Web服务器访问。 4. 清除缓存。有时,服务器可能无法在缓存中找到所请求的资源。您可以尝试清除服务器的缓存并重新启动服务器,然后再次尝试访问网页。 5. 检查服务器配置。如果所有其他方法都失败了,您应该检查服务器的配置文件以确保文件和文件路径正确。您还可以查看Tomcat日志文件以获取更多信息,并修复任何错误。 总的来说,要解决Tomcat的404错误,您需要仔细检查URL、文件路径、文件权限、缓存和服务器配置。通过这些步骤,您应该能够找到并解决问题,并让您的Web服务器正常运行。 ### 回答3: 一般情况下,tomcat:http状态 404 - 未找到是指在请求某个页面时,服务器无法找到客户端所请求的资源。造成这种情况的原因可能是多方面的,下面列举几种常见的解决方法: 1. 检查URL路径是否正确:确保在输入URL时没有出现拼写错误或者其他输入错误。URL路径应该和资源的实际文件路径一致。 2. 确认资源是否存在:当请求某个资源时,如果在服务器中不存在对应的文件,就会返回404错误。因此,需要确认所请求的资源实际上是否存在于服务器中。如果资源确实存在,可以尝试重启服务器等措施来解决问题。 3. 检查权限设置:如果所请求的资源受到权限限制,而客户端没有足够的权限来访问该资源,也会返回404错误。因此,需要确保所请求的资源没有被设置为只有特定的用户或用户组才能访问。 4. 检查服务器配置:如果发生404错误,有可能是因为服务器配置错误导致的。例如,如果服务器上安装了防火墙或者某些安全软件,这些软件可能会阻止客户端访问某些资源,从而导致404错误。因此,需要检查服务器的安全设置,确保客户端可以正常访问所需的资源。 总之,要解决tomcat:http状态 404 - 未找到问题,需要先确认所请求的资源是否存在,检查URL路径和权限设置是否正确,以及检查服务器配置是否出错。只有在找出问题所在后,才能有针对性地解决问题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值