Update: I've revised and split this post into two separate posts.
Cross-Site Request Forgery (CSRF) Attack: What It Is, How It Works, and How to Prevent It
CSRF vulnerability tricks authenticated users of an application to perform a dangerous activity on that application, simply by clicking a link. This post explains how CSRF works with a practical example, and shows how to protect against it, both as a user and a developer building web applications.
data:image/s3,"s3://crabby-images/b8876/b8876653de339d0cc6112998f12f247b30eb3e62" alt=""
How Rails Authenticity Tokens Protect Against CSRF Vulnerability
Rails protects your web application from CSRF attack by including an authenticity token in the HTML forms. This token is also stored in the user’s session. Upon receiving a request, Rails compares these two tokens to decide if the request is verified.
data:image/s3,"s3://crabby-images/15b9c/15b9ccb2519b5f60403929a3fce6f675eb96d27d" alt=""