I want to verify that my web application does not have a path traversal vulnerability.
I'm trying to use curl
for that, like this:
$ curl -v http://www.example.com/directory/../
I would like the HTTP request to be explicitly made to the /directory/../
URL, to test that a specific nginx rule involving proxy is not vulnerable to path traversal. I.e., I would like this HTTP request to be sent:
> GET /directory/../ HTTP/1.1
But curl
is rewriting the request as to the /
URL, as can be seen in the output:
* Rebuilt URL to: http://www.example.com/
(...)
> GET / HTTP/1.1
Is it possible to use curl
for this test, forcing it to pass the exact URL in the request? If not, what would be an appropriate way?
I'm not aware of a way to do it via
curl
, but you could always usetelnet
. Try this command:telnet www.example.com 80
You'll see:
Trying xxx.xxx.xxx.xxx... Connected to www.example.com. Escape character is '^]'.
You now have an open connection to www.example.com. Now just type in your command to fetch the page:
GET /directory/../ HTTP/1.1
And you should see your result. e.g.
HTTP/1.1 400 Bad Request