HTTP URL Address Encoding in Java

前端 未结 26 1410
醉酒成梦
醉酒成梦 2020-11-22 01:35

My Java standalone application gets a URL (which points to a file) from the user and I need to hit it and download it. The problem I am facing is that I am not able to encod

26条回答
  •  死守一世寂寞
    2020-11-22 02:12

    There is still a problem if you have got an encoded "/" (%2F) in your URL.

    RFC 3986 - Section 2.2 says: "If data for a URI component would conflict with a reserved character's purpose as a delimiter, then the conflicting data must be percent-encoded before the URI is formed." (RFC 3986 - Section 2.2)

    But there is an Issue with Tomcat:

    http://tomcat.apache.org/security-6.html - Fixed in Apache Tomcat 6.0.10

    important: Directory traversal CVE-2007-0450

    Tomcat permits '\', '%2F' and '%5C' [...] .

    The following Java system properties have been added to Tomcat to provide additional control of the handling of path delimiters in URLs (both options default to false):

    • org.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH: true|false
    • org.apache.catalina.connector.CoyoteAdapter.ALLOW_BACKSLASH: true|false

    Due to the impossibility to guarantee that all URLs are handled by Tomcat as they are in proxy servers, Tomcat should always be secured as if no proxy restricting context access was used.

    Affects: 6.0.0-6.0.9

    So if you have got an URL with the %2F character, Tomcat returns: "400 Invalid URI: noSlash"

    You can switch of the bugfix in the Tomcat startup script:

    set JAVA_OPTS=%JAVA_OPTS% %LOGGING_CONFIG%   -Dorg.apache.tomcat.util.buf.UDecoder.ALLOW_ENCODED_SLASH=true 
    

提交回复
热议问题