Rails 4 solution for "Can't verify CSRF token authenticity” json requests
Instead of complete turning off CSRF, you can do the following in Rails 4:
class ApplicationController < ActionController::Base
protect_from_forgery with: :null_session, if: Proc.new { |c| c.request.format == 'application/json' }
end
Written by David Paluy
Related protips
5 Responses
data:image/s3,"s3://crabby-images/2a007/2a00783fec335ac2d7d0e31835fdf2bad66be524" alt=""
Unfortunately, the above matches exactly. I changed your suggestion to:
class ApplicationController < ActionController::Base
protect_from_forgery with: :null_session,
if: Proc.new { |c| c.request.format =~ %r{application/json} }
end
Now it handles additional content types terms such as:
application/json; charset=utf-8
Thanks for your idea above, it got me past my problem.
data:image/s3,"s3://crabby-images/b4a47/b4a47c4a364c00ca41ad330eb271f99d4f4dc19f" alt=""
You don't have to match manually, there is an easier way:
protectfromforgery with: :null_session, if: Proc.new { |c| c.request.format.json? }</code></pre>
data:image/s3,"s3://crabby-images/e435a/e435a2ae07bb2fab005af0d660a4a121465149a7" alt=""
Using rails 4.1.5, if:
doesn't work, I had to
protect_from_forgery with: :null_session, only: Proc.new { |c| c.request.format.json? }
data:image/s3,"s3://crabby-images/bfb94/bfb9432c82aa6c0972bf8e9267782f38fc2cc347" alt=""
I am using Rails 4.2.5
My authentication is home made based on M. Hartl tutorial.
Everything worked well until yesterday.
Today, after a bundle update I cannot get a session for user logging in.
The error in the Puma server log is: "Can't verify CSRF token authenticity"
I attempted all the suggestions above but none is working in my case.
Any help to overcome this will be much appreciated.
data:image/s3,"s3://crabby-images/ddc21/ddc21ebf6ed5a62b823512f349531e8dbb3add4f" alt=""
¡Excelente!, muchas gracias David Paluy y a los usuarios que fueron mejorando el código.