Sensitive data should be passed either:
- Your computer by default typically logs the query string (in the browser history),
- The webserver at the other end by default logs the query string. This is bad if say passwords are being passed around that the webserver smartly only stores strong key-strengthened cryptographic hashes with random salts (e.g., bcrypt) to prevent the passwords being inadvertently obtained by attackers. Obviously, its not hard to log POST variables if you need to, but its not typically done.
- Sensitive data should generally only be passed when an action of some sort is being done based on that sensitive data; and in cases where you are doing some sort of action (like logging in; passing secure data to be stored/acted on in a database) you should use POST versus GET.
Note: Generally, the rules that prevent cross-site request forgeries (CSRF also known as XSRF) only get triggered for POST requests. GET is the intended HTTP request method for retrieving data from a web server that has no other effect (besides benign stuff like populating a log file saying this page was requested); POST is the protocol for a user to send data to do some action (e.g., like order something from a website; transfer money from your bank account; change your password). That is a random CSRF token typically is required by most frameworks for GET requests, but will often be required for POST requests.
A password is sensitive data and shouldn’t be transmitted over query string. There are several informationleakage scenarios:
- Query string is generally stored in server logs.
- Browsers will cache the query string
In addition to the other answers here, the query string is also stored in the webserver’s logfiles, HTTP Proxies, and can even be seen if SSL is used in conjunction with a SSL monitoring tools like Bluecoat.
No, sensitive data should not be sent via a HTTP “GET” and should always be sent via “POST”
One more reason you should use a POST is because GETs are more susceptible to CSRF attacks
- The URL will be displayed. Shoulder surfers may see it and learn things from that (e.g. a password).
- The user may bookmark it. This can be a feature; but it also means that the data gets written on the disk.
- Similarly, the URL will make it to the “history” so it will be written to disk anyway; and it might be retrieved afterwards. For instance, if the browser is Chrome, then a lunch-time attacker just has to type Ctrl+H to open the “history tab” and obtain all the query strings.
- If page is printed, the URL will be printed, including any sensitive information.
- URLs including query strings are also frequently logged on the web server, and those logs may not be secured appropriately.
- There are size limitations on the query string, which depend on the browser and the server (there is nothing really standard here, but expect trouble beyond about 4 kB).
Therefore, if the query string is a simple link target in an HTML page, then sensitive data should be transmitted as part of a POST form, not encoded in the URL itself. With programmatic downloads (the AJAX way), this is much less of an issue.
If it can be avoided I always avoid it. It’s just one more attack surface that should be left closed unless there’s a legitimate need to allow data to be passed in the query string.
There’s always also the off chance that you or a future developer won’t properly filter/sanitize the data, and open the attack surface even wider. Even in an insecure app, if you accidentally allow for an injection, a malicious attacker and inject XSS and XSRF script into your DB and use your non-sensitive app to attack others, so it’s just best to play it safe.
Shoulder surfing is another legitimate concern, depending on the environment. If your app is going to be used in a place where it’s possible (a library, a cubicle that someone can look into, and office with a desk facing the wrong direction, etc) it’s a potential concern. If the people using your app are all in rooms where the desk is pointed so that shoulder surfing isn’t a problem, don’t worry about it. but if you don’t know that for sure, and you don’t know that it will always be that way, it’s a concern.