SPOOFING AN AUTHENTICATION COOKIE
- Layout for this exercise:
data:image/s3,"s3://crabby-images/abd6e/abd6ebd4668aa1a906c9c90c865e07be52271a44" alt=""
1 - Authentication cookies
- Authentication cookies are the most common method used by web servers to know whether the user is logged in or not, and which account they are logged in with.
https://en.wikipedia.org/wiki/HTTP_cookie
- Without such a mechanism, the site would not know whether to send a page containing sensitive information, or require the user to authenticate themselves by logging in.
- The security of an authentication cookie generally depends on the security of the issuing website and the user's web browser, and on whether the cookie data is encrypted.
- Security vulnerabilities may allow a cookie's data to be read by a hacker, used to gain access to user data, or used to gain access (with the user's credentials) to the website to which the cookie belongs.
- In this exercise the OWASP WebGoat v5.4 will be used for the purpose of exemplifying the spoofing of an authentication cookie:
data:image/s3,"s3://crabby-images/c7f6b/c7f6ba15887e333ab2de5a69a894964b7e7e14cc" alt=""
2 - Session Management Flaws
- Going to Session Management Flaws -> Spoof an Authentication Cookie:
data:image/s3,"s3://crabby-images/3bb64/3bb64d4e84a2d24e528d37478885ad8482b32d9c" alt=""
- The scenario consists of a login web form that works correctly for two different username/password cases, for instance signing in with webgoat/webgoat and aspect/aspect the authentication is ok:
data:image/s3,"s3://crabby-images/dbac5/dbac53ba2eafa728b79068ef8ba151cb590e58d2" alt=""
data:image/s3,"s3://crabby-images/bfe7a/bfe7ae5866aab8a50e2485e0929bb0fe1b5b2933" alt=""
data:image/s3,"s3://crabby-images/c38b9/c38b9e67b1e5bbe90cf06fd0a616364392a35f13" alt=""
data:image/s3,"s3://crabby-images/aa9c0/aa9c007552a4b6d2876ecf576d28329d4c59dc65" alt=""
- However, the challenge is to achieve a successful authentication bypass for the user alice, what at first is rejected by the login process:
data:image/s3,"s3://crabby-images/81392/81392dbc5ca75795352072775ca97fdfd800199c" alt=""
data:image/s3,"s3://crabby-images/729a0/729a0976b96d913e524ef3eba437ed4515d3f867" alt=""
3 - Tampering the authentication process
- With the purpose of retrieving authentication cookies for webgoat/webgoat and aspect/aspect let's use the Tamper Data add-on of the browser Firefox:
data:image/s3,"s3://crabby-images/91e87/91e8748c3d153b4659458be48eba99f451beff32" alt=""
- Starting the tamper:
data:image/s3,"s3://crabby-images/3b51f/3b51f9ddd4c4deb2efb0707f0a16e737ff4419e4" alt=""
- Now, let's sign in with webgoat/webgoat:
data:image/s3,"s3://crabby-images/32572/32572f892080bdb1cf5f7dbab95240b5413eb690" alt=""
- Tampering:
data:image/s3,"s3://crabby-images/2ca3d/2ca3d5bf738e55d7ca2c7f0077855af9a056295b" alt=""
- Copying the cookie:
data:image/s3,"s3://crabby-images/6646e/6646ec0b34d90fa546d6898f8c285691df253627" alt=""
- Storing the authentication cookie for further study:
data:image/s3,"s3://crabby-images/8a303/8a303743eefc0e21aabff94d11398d24a869e7ac" alt=""
- Same thing for aspect/aspect:
data:image/s3,"s3://crabby-images/29fea/29feaf19f90acd5346d299e5e99b3e312e9f6e20" alt=""
data:image/s3,"s3://crabby-images/8eafc/8eafc27560e4bb7831a3a482d54d494b188f14db" alt=""
data:image/s3,"s3://crabby-images/573bc/573bc87162b6444729e1dd2e12bc1e767b2ac81c" alt=""
data:image/s3,"s3://crabby-images/3a555/3a555a932dc47d98178ee2b0d05e1897aa537b82" alt=""
- As a result of the tampering, now we have two authentication cookies, one for webgoat/webgoat and the other one for aspect/aspect:
data:image/s3,"s3://crabby-images/da3b4/da3b40b69806623e892d106ce03f8ea60741a9c4" alt=""
- Comparing the two cookies it is clear that both start by 65432 and end up with two different strings: ubphcfx and udfqtb
4 - Decoding/encoding the cookies
- Going to:
yehg.net/encoding
data:image/s3,"s3://crabby-images/fb3f6/fb3f626109729087e8d34fdcbbc3f05e7bb69980" alt=""
- Entering the string ubphcfx and reversing:
data:image/s3,"s3://crabby-images/f36fd/f36fd916a469afb0fcab59c3a61248f94d74bbf2" alt=""
data:image/s3,"s3://crabby-images/276ca/276ca5ac88e15736ba2a18144958bd10c7e1111a" alt=""
data:image/s3,"s3://crabby-images/a0dfa/a0dfad92bfac6790747b96517523df4a373f4b87" alt=""
- Decoding with Char-- (shifting down one character):
data:image/s3,"s3://crabby-images/77916/77916f478c78eaba693df194965a96654e748fac" alt=""
- The result is the expected webgoat:
data:image/s3,"s3://crabby-images/a5da3/a5da384373288b2e27d7a5865c9bc13841db50c2" alt=""
- Same process with the authentication cookie udfqtb obtained for aspect/aspect:
data:image/s3,"s3://crabby-images/b410c/b410c41b5877e4587c97de4ae8a636e8a51e09d9" alt=""
- So now what we can do is to follow the reverse method with alice in order to achieve a similar string to build a new authentication cookie:
data:image/s3,"s3://crabby-images/d9314/d93141adb5f8db1ec3c2e98a2dd517bc7006b8bb" alt=""
- Reversing and encoding with Char++ (shifting up one character):
data:image/s3,"s3://crabby-images/06ff5/06ff51ea917710b2f948328a1f89b0ee8e0f024c" alt=""
data:image/s3,"s3://crabby-images/b25b1/b25b16c88c6a73532b7cb99dfcf1890b3e00aa86" alt=""
data:image/s3,"s3://crabby-images/771cc/771cc2b4dfae7f42898905cc9cc2946b36bb76e9" alt=""
- The result is:
data:image/s3,"s3://crabby-images/2eea3/2eea3956af151f09a42f456cf0e4998b0ba9cfe1" alt=""
- Actually the encoding process is very simple, consisting of just reversing plus shifting one character:
wegboat -> taogbew -> ubphcfx
aspect -> tcepsa -> udfqtb
alice -> ecila -> fdjmb
- To build alice's cookie the string fdjmb is prepended to 65432 in this way:
data:image/s3,"s3://crabby-images/50062/5006251d84d59c84154cc2dfc983c24ff802558b" alt=""
5 - Launching the cookie spoofing attack
- Now, let's tamper again an authentication session for webgoat/webgoat:
data:image/s3,"s3://crabby-images/5a055/5a0552d780b0f9b9e1afa6ac119e19f48e42fa43" alt=""
data:image/s3,"s3://crabby-images/44a22/44a22ad6a8b87387613314e8ad2b81fc8f3c464e" alt=""
data:image/s3,"s3://crabby-images/c7540/c7540a957369802ee203bbf4dd48056bd2e1fceb" alt=""
- At this moment, let's copy alice's crafted cookie and paste it into the cookie field:
data:image/s3,"s3://crabby-images/3c3e4/3c3e486bcd84990b9d568db125c6f62dc8205f1a" alt=""
data:image/s3,"s3://crabby-images/480be/480beeb2c4350b4f407ed6afea7048a20745d737" alt=""
- Clicking OK:
data:image/s3,"s3://crabby-images/32f5a/32f5a6b102f561bba5694412f75088a962fdcccd" alt=""
- Finally the attack is successful and the spoofed user alice becomes authenticated:
data:image/s3,"s3://crabby-images/4c9c6/4c9c61c5fb059137f5409308058c5575680bf6fb" alt=""