在$.ajaxSetup中的beforeSend + 在$.ajax中的beforeSend
在$.ajaxSetup中的beforeSend + 在$.ajax中的beforeSend
为了解决CSRF问题,我使用了客户端的Ajax设置:\n
$.ajaxSetup({ beforeSend: function(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]); // 是否以我们想要的名称开头? 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))) { // 仅将令牌发送到相对URL,即本地URL。 xhr.setRequestHeader("X-CSRFToken", getCookie('csrftoken')); } } });
\n直到今天,一切都运行良好。\n但是现在我需要在发送请求之前进行一些检查:\n
var check; //... $.ajax({ //... beforeSend: function(xhr){ if (check == 1){ xhr.abort(); } }, success: function(data){ //... } });
\nCSRF验证失败。请求被取消。\n据我理解,我只是取消了新函数的ajaxSetup操作。\n如何将这两个功能结合起来?