Test HTTP Methods (WSTG-CONF-06)
WSTG-CONF-06
Summary
HTTP offers a number of methods (or verbs) that can be used to perform actions on the web server. While GET and POST are by far the most common methods that are used to access information provided by a web server, there are a variety of other methods that may also be supported, and can sometimes be exploited by attackers.
RFC 7231 defines the main valid HTTP request methods (or verbs), although additional methods have been added in other RFCs, such as RFC 5789. Several of these verbs have bee re-used for different purposes in RESTful applications, listed in the table below.
Test Objectives
Enumerate supported HTTP methods.
Test for access control bypass.
Test HTTP method overriding techniques.
How to Test
Discover the Supported Methods
To perform this test, the tester needs some way to identify which HTTP methods are supported by the web server that is being examined. The simplest way to do this is to make an OPTIONS
request to the server:
The server should then response with a list of supported methods:
However, some servers may not respond to OPTIONS
requests, or may return inaccurate information. Additionally, servers may support different methods for different paths - so just because a method is not supported for the root /
directory, this doesn't necessarily mean that it won't be supported elsewhere.
An more reliable way to test for supported methods is to simply make a request with that method type, and examine the server response. If the method is not permitted, the server should return a 405 Method Not Allowed
status.
Note that some servers treat unknown methods as equivalent to GET
, so they may respond to arbitrary methods, such as the request shown below. This can occasionally be useful to evade a web application firewall, or any other filtering that blocks specific methods.
Requests with arbitrary methods can also be made using curl with the -X
option:
There are also a variety of automated tools that can attempt to determine supported methods, such as the http-methods
Nmap script. However, these tools may not test for dangerous methods (i.e, methods that may cause changes such as PUT
or DELETE
), or may unintentionally cause changes to the web server if these methods are supported. As such, they should be used with care.
PUT and DELETE
The PUT
and DELETE
methods can have different effects, depending on whether they are being interpreted by the web server or by the application running on it.
Legacy Web Servers
Some legacy web servers allowed the use of the PUT
method to create files on the server. For example, if the server is configured to allow this, the request below would create a file on the server called test.html
with the contents <script>alert(1)</script>
.
Similar requests can also be made with cURL:
This allows an attacker to upload arbitrary files to the webserver, which could potentially result in a full system compromise if they are allowed to upload executable code such as PHP files. However, this configuration is extremely rare, and is unlikely to be seen on any modern systems.
Similarly, the DELETE
method can be used to delete files from the webserver. Note that this is a destructive action, so care should be taken when testing this method.
Or with cURL:
RESTful APIs
By contrast, the PUT
and DELETE
methods are commonly used by modern RESTful applications to create and delete objects. For example, the API request below could be used to create a user called "foo" with a role of "user":
A similar request with the DELETE method could be used to delete an object.
Although it may be reported by automated scanning tools, the presence of these methods on a RESTful API is not a security issue. However, this functionality may have other vulnerabilities (such as weak access control), and should be thoroughly tested.
TRACE
The TRACE
method (or Microsoft's equivalent TRACK
method) causes the server to echo back the contents of the request. This lead to a vulnerability called Cross-Site Tracing (XST) being published in 2003 (PDF), which could be used to access cookies that had the HttpOnly
flag set. The TRACE
method has been blocked in all browsers and plugins for many years, and as such this issue is no longer exploitable. However, it may still be flagged by automated scanning tools, and the TRACE
method being enabled on a web server suggests that is has not been properly hardened.
CONNECT
The CONNECT
method causes the web server to open a TCP connection to another system, and then to pass traffic from the client through to that system. This could allow an attacker to proxy traffic through the server, in order to hide their source address, access internal systems or access services that are bound to localhost. An example of a CONNECT
request is shown below:
PATCH
The PATCH
method is defined in RFC 5789, and is used to provide instructions for how an object should be modified. The RFC itself does not define what format these instructions should be in, but various methods are defined in other standards, such as the RFC 6902 - JavaScript Object Notation (JSON) Patch.
For example, if we have an user called "foo" with the following properties:
The following JSON PATCH request could be used to change the role of this user "admin", without modifying the email address:
Although the RFC states that it should include instructions for how the object should be modified, the PATCH
method is commonly (mis)used to include the changed content instead, as shown below. Much like the previous request, this would change the "role" value to "admin" without modifying the rest of the object. This is in contrast to the PUT
method, which would overwrite the entire object (and thus result in an object with no "email" attribute).
As with the PUT
method, this functionality may have access control weaknesses or other vulnerabilities. Additionally, applications may not perform the same level of input validation when modifying an object as they do when creating one. This could potentially allow malicious values to be injected (such as in a stored cross-site scripting attack), or could allow broken or invalid objects that may result in business logic related issues.
Testing for Access Control Bypass
If a page on the application redirects users to a login page with a 302
code when they attempt and access it directly, it may be possible to bypass this by making a request with a different HTTP method, such as HEAD
, POST
or even a made up method such as FOO
. If the web application responds with a HTTP/1.1 200 OK
rather than the expected HTTP/1.1 302 Found
then it may be possible to bypass the authentication or authorization. The example below shows how a HEAD
request may result in a page setting administrative cookies, rather than redirecting the user to a login page:
Alternatively, it may be possible to make direct requests to pages that cause actions, such as:
Or:
Testing for HTTP Method Overriding
Some web frameworks provide a way to override the actual HTTP method in the request by emulating the missing HTTP verbs passing some custom header in the requests. The main purpose of this is to circumvent a middleware application (such as a proxy or web application firewall) which blocks specific methods. The following alternative HTTP headers could potentially be used:
X-HTTP-Method
X-HTTP-Method-Override
X-Method-Override
In order to test this, in the scenarios where restricted verbs such as PUT
or DELETE
return a 405 Method not allowed
, replay the same request with the addition of the alternative headers for HTTP method overriding, and observe how the system responds. The application should respond with a different status code (e.g. 200 OK
) in cases where method overriding is supported.
The web server in the following example does not allow the DELETE
method and blocks it:
After adding the X-HTTP-Method
header, the server responds to the request with a 200:
Remediation
Ensure that only the required methods are allowed, and that the allowed methods are properly configured.
Ensure that no workarounds are implemented to bypass security measures implemented by user-agents, frameworks, or web servers.
Tools
References
Last updated