乐9乐开发网
广告位招商联系QQ:123077622
 
广告位招商联系QQ:123077622

Java 在方法名称中找到无效字符. HTTP方法必须是令牌

乐9乐开发网 https://welsheng.com 2020-03-10 12:20 出处:网络 作者:乐9乐开发网整理
这不是其他问题(或者至少是我遇到的问题)的重复,因为我在代码中的任何地方都不使用SSL / HTTPS.我还能够确认这些错误来自我的系统而不是外部源(如机器人).如果它很简单,那么我道歉,几个月前我才开始使用 Spring Boot. 我正在开发一个物联网系统,我将带有传感器的Raspberry Pi Zero W发送到现场. Raspberry Pi通过蓝牙LE获取传感器数据,HTTP将数据发送
这不是其他问题(或者至少是我遇到的问题)的重复,因为我在代码中的任何地方都不使用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:解析HTTP请求头时出错

注意:将在DEBUG级别记录更多出现的HTTP头解析错误.

java.lang.IllegalArgumentException:方法名称中找到无效字符. HTTP方法名称必须是令牌

        在org.apache.coyote.http11.Http11InputBuffer.parseRequestLine(Http11InputBuffer.java:421)〜[tomcat-embed-core-8.5.11.jar!/:8.5.11](堆栈跟踪的其余部分)

正如我上面提到的,我没有在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

非常感谢您的帮助!

我有一个类似的问题,并添加

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

为我解决了这个问题.

扫码领视频副本.gif

0

精彩评论

暂无评论...
验证码 换一张
取 消