这与其他问题(或至少是我遇到过的问题)不重复,因为我在代码中的任何地方都没有使用SSL / HTTPS。我还能够确认这些错误来自我的系统而不是外部源(如机器人)。如果它很简单,那么我道歉,几个月前我才开始使用Spring Boot。
我正在开发一个物联网系统,我将带有传感器的Raspberry 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 header
Note: 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 tokens
at
org.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个传感器读数,所有这些都在不同的日期/时间)。
数据在离开Raspberry Pi时是否已损坏? requests.post
有一些我不知道的奇怪行为吗?我用Spring编写的代码是否会以某种方式影响Tomcat?我不知道为什么会这样,我遇到的所有其他答案都说它通常是因为HTTPS到HTTP的连接。我的application.properties文件只有server.port = 80
非常感谢您的帮助!
答案 0 :(得分:0)
我有类似的问题并添加了
<dependency>
<groupId>com.fasterxml.jackson.core</groupId>
<artifactId>jackson-databind</artifactId>
<version>2.6.3</version>
</dependency>
为我解决了这个问题。
答案 1 :(得分:-1)
#Increase header buffer size
#server.tomact.max-http-header-size: 8192 this is lose efficacy
server.max-http-header-size=15360