在方法名称中发现无效字符,HTTP方法必须是令牌

x4shl7ld  于 2022-10-23  发布在  Spring
关注(0)|答案(4)|浏览(147)

编辑:我不再在这个地方工作了,我们还是转到了node.js,所以我不能验证是否有人的答案是正确的。请投票关闭(只需再投票一次)。
这不是其他问题(或者至少是我遇到的问题)的重复,因为我在代码中的任何地方都没有使用SSL/HTTPS。我还能够确认这些错误来自我的系统,而不是外部来源(如机器人)。如果是简单的东西,那么我很抱歉,我几个月前才开始使用Spring Boot。
我正在开发一个物联网系统,在这个系统中,我将一个带有传感器的覆盆子Pi Zero W发送到现场。Raspberry PI通过蓝牙LE获取传感器数据,并且HTTP将数据发送到Spring Boot服务器(托管在AWS EC2示例上)。奇怪的是,服务器在一段时间内(在本例中是3周)完全正常地获取数据,然后我突然从Spring/Tomcat那里得到了这个异常:
2017-06-03 06:17:07.508 INFO 19927 --- [p-nio-80-exec-8]o.apache.coyote.http11.Http11Processor : Error parsing HTTP request headerNote: further occurrences of HTTP header parsing errors will be logged at DEBUG level.
java.lang.IllegalArgumentException: Invalid character found in method name. HTTP method names must be tokensatorg.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:421) ~[tomcat-embed-core-8.5.11.jar!/:8.5.11] (rest of the stack trace)
正如我在上面提到的,我没有在Spring Boot或Raspberry PI中使用HTTPS。由于Raspberry PI将部署到远程位置,因此我不会更改代码。
在Raspberry PI上运行的程序是用Python编写的,我使用requests.post方法将数据发送到服务器。
我在该系统的早期部署中也注意到了这种行为,该系统使用Android设备发送数据。所以我不认为这些客户有什么问题。
我对服务器进行了相当多的测试,特别是在添加新功能时,我以前从未遇到过这个错误(除了在以前的部署中)。一旦发生这个错误,它似乎就会继续发生(我连续丢失了3个传感器读数,都是在不同的日期/时间)。
数据在离开树莓PI的过程中会被破坏吗?requests.post是不是有一些我不知道的奇怪行为?我使用Spring编写的代码会以某种方式影响Tomcat吗?我不知道为什么会发生这种情况,我遇到的所有其他答案都说这通常是因为HTTPS到HTTP的连接。我的应用程序.properties文件只有server.port=80
非常感谢您的帮助!

jqjz2hbq

jqjz2hbq1#

我遇到了类似的问题,并补充说

<dependency>
    <groupId>com.fasterxml.jackson.core</groupId>
    <artifactId>jackson-databind</artifactId>
    <version>2.6.3</version>
</dependency>

为我修复了这个问题。

dwthyt8l

dwthyt8l2#


# Increase header buffer size

# server.tomact.max-http-header-size: 8192   this is lose efficacy

server.max-http-header-size=15360
q35jwt9p

q35jwt9p3#

有时,当服务器未设置为通过HTTPS处理安全请求,但客户端正在以这种方式发送它们时,就会发生这种情况。当我犯了这个错误时,我得到的回复是这样的:
Invalid character found in method name [0x160x030x010x000xf70x010x110x110xf30x030x030x0e0xef0x9d10x8dV0xff0x000x1d0xcf0xffE0x4!0x5}0xa40xef/0xdf ]. HTTP method names must be tokens

f4t66c6m

f4t66c6m4#

今天,我也面临着类似的问题。我将URL从HTTPS更改为Http,这解决了问题。

相关问题