在方法名称中找到无效字符。 HTTP方法必须为令牌

问题描述 投票:4回答:2

这不是其他问题(或至少我遇到的问题)的重复,因为我在代码中的任何地方都没有使用SSL / HTTPS。我还能够确认这些错误是我的系统造成的,而不是外部来源(例如bot)。如果很简单,那么我道歉,我只是几个月前才开始使用Spring Boot。

我正在开发一个物联网系统,在该系统中,我将带有传感器的Raspberry Pi Zero W发送到现场。 Raspberry Pi通过蓝牙LE获取传感器数据,然后将数据HTTP 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设备发送数据。因此,我认为客户没有任何问题...

我已经对服务器进行了相当多的测试,尤其是当我添加新功能时,并且以前从未遇到此错误(以前的部署中除外)。一旦发生此错误,就好像它继续发生(我连续三天丢失了三个传感器读数,都在不同的日期/时间)。

数据离开Raspberry Pi时是否受到破坏? requests.post有我不知道的某些奇怪行为吗?我使用Spring编写的代码是否会以某种方式影响Tomcat?我不知道为什么会这样,我遇到的所有其他答案都说这通常是因为HTTPS到HTTP的连接。我的application.properties文件只有server.port = 80

非常感谢您的帮助!

java python tomcat spring-boot raspberry-pi
2个回答
0
投票

我有类似的问题,然后添加

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

为我解决了这个问题。


-1
投票
#Increase header buffer size
#server.tomact.max-http-header-size: 8192   this is lose efficacy 
server.max-http-header-size=15360
© www.soinside.com 2019 - 2024. All rights reserved.