Testing for server-side parameter pollution in REST paths

A RESTful API may place parameter names and values in the URL path, rather than the query string. For example, consider the following path:

/api/users/123 The URL path might be broken down as follows:

/api is the root API endpoint. /users represents a resource, in this case users. /123represents a parameter, here an identifier for the specific user. Consider an application that enables you to edit user profiles based on their username. Requests are sent to the following endpoint:

GET /edit_profile.php?name=peter This results in the following server-side request:

GET /api/private/users/peter An attacker may be able to manipulate server-side URL path parameters to exploit the API. To test for this vulnerability, add path traversal sequences to modify parameters and observe how the application responds.

You could submit URL-encoded peter/../admin as the value of the name parameter:

GET /edit_profile.php?name=peter%2f..%2fadmin This may result in the following server-side request:

GET /api/private/users/peter/../admin If the server-side client or back-end API normalize this path, it may be resolved to /api/private/users/admin.

Last updated