【问题标题】:Invalid character found in method name. HTTP method must be tokens在方法名称中发现无效字符。 HTTP 方法必须是令牌
【发布时间】:2017-11-06 10:33:07
【问题描述】:

编辑:我不再在这个地方工作,我们还是切换到了 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 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 atorg.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

非常感谢您的帮助!

【问题讨论】:

  • 显然我还没有关闭它的声誉。我无法再验证提供的答案是否正确。请参阅下面的评论。谢谢大家!
  • 这和python有什么关系?
  • 我使用 Python 在树莓派上编写了物联网网关。因为我是 Python 新手,所以我不确定我是否做错了什么。没关系,因为我不再可以验证任何人的解决方案是否正确,因为我不再在那个地方工作了。
  • 我还注意到我可以结束这个问题,并且我投票决定这样做。如果其他人能够投票,那就太好了。不过,我有点希望 SO 可以让 OP 自己关闭问题。

标签: java python tomcat spring-boot raspberry-pi


【解决方案1】:

我遇到了类似的问题并添加了

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

为我解决了这个问题。

【讨论】:

  • 感谢您的回答 Siraj!不幸的是,我不再参与那个项​​目,我们最终还是切换到了 Node.js。我不知道你为什么被否决,所以我会投票给你,直到有人提供解释。我会看看我是否可以关闭这个问题。
【解决方案2】:
#Increase header buffer size
#server.tomact.max-http-header-size: 8192   this is lose efficacy 
server.max-http-header-size=15360

【讨论】:

  • 这将如何解决?为什么它会“失效”?
猜你喜欢
  • 2019-05-19
  • 1970-01-01
  • 1970-01-01
  • 2021-01-20
  • 2022-06-17
  • 1970-01-01
  • 2016-10-16
  • 1970-01-01
  • 2021-06-28
相关资源
最近更新 更多