csrf_token to ajax requests

10 views
Skip to first unread message

jussi

unread,
Mar 15, 2011, 4:59:27 AM3/15/11
to django-page-cms
Hi, there was a problem using django-page-cms in django-1.2.5. Here's
the fix: add following javascript to pages.js file
---

$('html').ajaxSend(function(event, xhr, settings) {
function getCookie(name) {
var cookieValue = null;
if (document.cookie && document.cookie != '') {
var cookies = document.cookie.split(';');
for (var i = 0; i < cookies.length; i++) {
var cookie = jQuery.trim(cookies[i]);
// Does this cookie string begin with the name we
want?
if (cookie.substring(0, name.length + 1) == (name +
'=')) {
cookieValue =
decodeURIComponent(cookie.substring(name.length + 1));
break;
}
}
}
return cookieValue;
}
if (!(/^http:.*/.test(settings.url) || /
^https:.*/.test(settings.url))) {
// Only send the token to relative URLs i.e. locally.
xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken'));
}
});
---
Reply all
Reply to author
Forward
0 new messages