java - 在方法名称中发现无效字符。 HTTP 方法必须是 token

标签 java python tomcat spring-boot raspberry-pi

编辑:我不再在这个地方工作,无论如何我们切换到 node.js,所以我无法验证是否有人的答案是正确的。请投票关闭(只需要一个)。

这不是其他问题(或者至少是我遇到的问题)的重复,因为我没有在代码中的任何地方使用 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 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 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 被部署到远程位置,因此我不会更改代码。

在树莓派上运行的程序是用 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>

为我解决了这个问题。

关于java - 在方法名称中发现无效字符。 HTTP 方法必须是 token ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44372545/

相关文章:

更改端口时Tomcat设置错误

java - 解析 XSL 时 Saxon 中的 NullPointerException

java - 对 AWS EC2/EBS 资源使用较长的 ID

python - 当我使用 findAll 时,BeautifulSoup 总是返回 null

python - Tkinter 按钮调用对象上的方法

bash - sudo -u(用户)cmd 在 bash 脚本中不起作用

java - 在这种情况下如何避免在转换为泛型时发出警告?

java - Soap 请求超时不起作用

扫描字符串文字时的 Python EOL

eclipse - 依赖项没有部署到 tomcat 中