Mastering Postman: Cookie and Token Authentication
In this article, we will dive deep into the realms of Cookie Authentication and Token Authentication, two pivotal security strategies.
In the realm of web services and API management, understanding the core mechanisms that secure the communication between the client and server is crucial. In this article, we will dive deep into the realms of Cookie Authentication and Token Authentication, two pivotal security strategies. Our journey will include practical examples using Postman and echoAPI Interceptor, highlighting their implementation and nuances.
data:image/s3,"s3://crabby-images/77725/77725a4eddc238204e8bfe081ad9626d79c42eb1" alt="Postman.png Postman.png"
What Are Cookies?
A cookie is a small piece of text stored on the client's machine that is used primarily for session management, user personalization, and tracking user behavior. In a key=value format, cookies operate serving as tiny data keepers.
data:image/s3,"s3://crabby-images/dea41/dea4164811c47ca8307b16a4e4922e4ecfc8d8a1" alt=""
How Cookie Authentication Works
data:image/s3,"s3://crabby-images/40f11/40f11a0dc198471ab840475c200133a7359b5cfd" alt="image.png image.png"
Cookie authentication is a server-side method of maintaining state between HTTP transactions. It works as follows:
- Initial Request by Client: During the first visit to a server, if authentication is needed, the server generates a cookie.
- Cookie in Response Header: This cookie is sent back with the response, embedded in the
Set-Cookie
header. - Subsequent Requests: On subsequent requests, the client returns this cookie to the server in the
Cookie
header, allowing the server to validate the session.
Types of Cookies:
- Session Cookies: Stored in memory and deleted when the browser is closed.
- Persistent Cookies: Stored on the hard drive until they expire (as defined by their expiration date) or until the user deletes the cookie.
To inspect cookies, one can use the browser's Developer Tools under the Application panel to see details such as Name, Value, Domain, Path, and Expires/Max-Age.
data:image/s3,"s3://crabby-images/c2765/c2765b590d496f2575bc0fa61c31479ac9e4d33f" alt="cookies.jpg cookies.jpg"
Practical Example: Debugging API Authentication
Let us detail the steps to understand cookie and token authentication via practical debugging:
Tools Used:
- EchoAPI Interceptor: A modern tool for capturing and inspecting HTTP traffic.
data:image/s3,"s3://crabby-images/b302b/b302bf0f98bdd4f752bf92f1ed64c1f094ffe8c7" alt="EchoAPI Interceptor.png EchoAPI Interceptor.png"
data:image/s3,"s3://crabby-images/70f8a/70f8a161c72db29d2b4352d85f61bce9f79bd389" alt=""
Steps in Action:
1. Setup:
Post login, echoAPI Interceptor automatically captures the traffic including URLs, parameters, and cookies of the session.
data:image/s3,"s3://crabby-images/85ab0/85ab027c49bd9a9abda450eee811f268332c7bca" alt="img_v3_02iq_53016773-c8be-4279-811f-5b4c945ec37g.jpg img_v3_02iq_53016773-c8be-4279-811f-5b4c945ec37g.jpg"
Navigate to the login page at https://app.echoapi.com/login
and perform the login with credentials.
data:image/s3,"s3://crabby-images/6a326/6a3266c7f5c4e9852f4ef20794ec19dede14504c" alt="img_v3_02iq_dee9da85-e16f-4892-b691-2bc1b48f2dag.jpg img_v3_02iq_dee9da85-e16f-4892-b691-2bc1b48f2dag.jpg"
2. Copying curl for API:
Right-click the API and choose to copy as curl.
data:image/s3,"s3://crabby-images/1f654/1f654b4bec7278d77f88cb006b4b3df56b1c31f3" alt="img_v3_02iq_002452d0-654e-4ba9-aac5-dba69492f94g.jpg img_v3_02iq_002452d0-654e-4ba9-aac5-dba69492f94g.jpg"
Click on the login
API from the captured list, send the request, and ensure it is debuggable.
data:image/s3,"s3://crabby-images/35cea/35cea8c86ff4396da0bafd2a48c3a45fe7636134" alt="img_v3_02iq_a9c04c05-0409-4cde-9424-f72c7718ff4g.jpg img_v3_02iq_a9c04c05-0409-4cde-9424-f72c7718ff4g.jpg"
3. Importing to Postman:
Bring the curl command into Postman to setup the environment for further requests.
data:image/s3,"s3://crabby-images/e32c9/e32c9cb9d0b63d6afc91ae603645151c04973622" alt="img_v3_02iq_c33e79ae-664f-4706-b194-335a905f379g.jpg img_v3_02iq_c33e79ae-664f-4706-b194-335a905f379g.jpg"
4. Token Setup in Postman:
After sending a request via the login/email_login
endpoint, extract the token from the response and set it as a global variable:
var data = JSON.parse(responseBody);
pm.globals.set("token", data.data.token);
data:image/s3,"s3://crabby-images/81e4b/81e4b638f1dd9a2fbff7704468e9208e4ef64b3c" alt="img_v3_02iq_3e98f578-836b-4d4e-9e75-dfd5eae1f98g.jpg img_v3_02iq_3e98f578-836b-4d4e-9e75-dfd5eae1f98g.jpg"
data:image/s3,"s3://crabby-images/9e7ff/9e7ffad43b43c79a2827163ec119f63161a6e50d" alt=""
5. Using Token in Headers:
- Switch to the
api/online
endpoint in Postman.
In the Headers section, replace the value of echoapitoken
with the token variable {{token}}
acquired earlier, send the request, and observe the output.
data:image/s3,"s3://crabby-images/5c437/5c437e93532905df09cd8a0999993a59120a731d" alt="img_v3_02iq_d719af85-13fe-4b35-854c-93b9af9fdefg.jpg img_v3_02iq_d719af85-13fe-4b35-854c-93b9af9fdefg.jpg"
6. Attempting Cookie Authentication:
The result indicates failure, as the API requires authentication via tokens, hence validating the different authentications in use.
data:image/s3,"s3://crabby-images/754ae/754ae11f7d4b8dae47697a5aa5b91020f6dfe6e3" alt="img_v3_02iq_4cbcd275-2ee6-4922-9cf2-a9b5d763bd9g.jpg img_v3_02iq_4cbcd275-2ee6-4922-9cf2-a9b5d763bd9g.jpg"
Evaluate attempting a request to api/online
with all cookies deleted or disabled.
data:image/s3,"s3://crabby-images/5aece/5aece5325b580f786752894974a63d35ac75cd00" alt="img_v3_02iq_fd50f08f-beae-4b0a-8e64-9fb2161282bg.jpg img_v3_02iq_fd50f08f-beae-4b0a-8e64-9fb2161282bg.jpg"
data:image/s3,"s3://crabby-images/b9e7c/b9e7cda3b02ffbb33647396b9034e467383d66e2" alt=""
Conclusion
Through this comprehensive guide and practical example, you have learned about the mechanisms of Cookie and Token authentications, how to inspect and manipulate these using tools like Postman and echoAPI Interceptor. Cookie and Token Authentication serve different purposes and scenarios where the former manages sessions and the latter secures API calls via tokens that represent user credentials or session states.
Understanding and implementing these authentication mechanisms properly can bolster the security and functionality of web applications and services, providing a more secure and responsive user experience.