Skip to content
Advertisement

Tomcat 8 is not able to handle get request with ‘|’ in query parameters?

I am using Tomcat 8. In one case I need to handle external request coming from external source where the request has a parameters where it is separated by |.

Request is looks like this:

http://localhost:8080/app/handleResponse?msg=name|id|

In this case I am getting following error.

JavaScript

EDIT 1

It works with Apache Tomcat 8.0.30 but not with Tomcat 8.5

Advertisement

Answer

This behavior is introduced in all major Tomcat releases:

  • Tomcat 7.0.73, 8.0.39, 8.5.7

To fix, do one of the following:

  • set relaxedQueryChars to allow this character (recommended, see Lincoln’s answer)
  • set requestTargetAllow option (deprecated in Tomcat 8.5) (see Jérémie’s answer).
  • you can downgrade to one of older versions (not recommended – security)

Based on changelog, those changes could affect this behavior:

Tomcat 8.5.3:

Ensure that requests with HTTP method names that are not tokens (as required by RFC 7231) are rejected with a 400 response

Tomcat 8.5.7:

Add additional checks for valid characters to the HTTP request line parsing so invalid request lines are rejected sooner.


The best option (following the standard) – you want to encode your URL on client:

JavaScript

or just query string:

JavaScript

It will secure you from other problematic characters (list of invalid URI characters).

Advertisement