[Security] Automatically adding CSRF tokens to ajax calls when using jQuery
地址:http://erlend.oftedal.no/blog/?blogid=118
When building a ajax based application, you want to protect any POST
request against CSRF
attacks. If you are using jQuery, then jQuery provides a lot of
convenience methods for ajax calls ($.get(),
$.post(), $.getJSON()
etc.) and it would be a shame if you
would have to duplicate adding CSRF tokens to all your ajax calls manually or by
going back to $.ajax()
, because
the convenience method didn‘t support the way you wanted to add the token. But
jQuery, being the customizable framework it is, of course allows you to add
these kinds of things through events.
Session based tokens
If you are using session based tokens, you probably generate a secure token when generating the session, and store that token in the session. When a request comes back to the server, you check that the token is included in the request and compare it to what‘s in the session. If it‘s the same token, you accept the request, if not you reject it.
To use this token with jQuery, you need to make it available to javascript. You typically do this by adding it as a javascript variable.
var csrf_token = ‘<%= token_value %>‘;
Next, the trick is to bind to the global ajaxSend
event, and add the token to any POST
request
$("body").bind("ajaxSend", function(elm, xhr, s){
if (s.type ==
"POST") {
xhr.setRequestHeader(‘X-CSRF-Token‘, csrf_token);
}
});
In the example above I add the token as a request header, but you could optionally add it as a form post parameter in stead.
Double-submit of cookie
When using double submit of cookie, you adjust the example above to extract
the value of csrf_token
from the cookies
instead.
Update: Bug in jQuery 1.5.0
This does not work in jQuery 1.5.0 because of bug 8360. Looks like it will be fixed in 1.5.1. Works in 1.4.4.
[Security] Automatically adding CSRF tokens to ajax calls when using jQuery--转,古老的榕树,5-wow.com
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。