$.ajaxSetup 中的 beforeSend + $.ajax 中的 beforeSend

Posted

技术标签:

【中文标题】$.ajaxSetup 中的 beforeSend + $.ajax 中的 beforeSend【英文标题】:beforeSend in $.ajaxSetup + beforeSend in $.ajax 【发布时间】:2014-08-01 17:05:21 【问题描述】:

为了解决 CSRF 问题,我使用 Ajax 的客户端设置:

$.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]);
                    // 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'));
        
    
);

直到今天,一切正常。 但现在我需要在发布前做一些检查:

var check;
//...
$.ajax(
    //...
    beforeSend: function(xhr)
        if (check == 1)
            xhr.abort();
        
    ,
    success: function(data)
        //...
    
);

CSRF 验证失败。请求中止。 据我了解,我只是取消了新功能的 ajaxSetup 操作。 如何将这两件事结合起来?

【问题讨论】:

【参考方案1】:

使用$(document).ajaxSend(function(ev, jqhr, settings) ... ) 而不是.ajaxSetup

正如你所说,.ajaxSetup 定义了一个默认处理程序,然后可以覆盖该处理程序。使用.ajaxSend,您可以注册多个处理程序以在发送ajax 请求之前触发。与自定义 beforeSend 处理程序一起工作正常。

【讨论】:

以上是关于$.ajaxSetup 中的 beforeSend + $.ajax 中的 beforeSend的主要内容,如果未能解决你的问题,请参考以下文章

ajaxSetup设置Ajax请求的默认值

使用 ajaxSetup dataFilter 的并行请求

监测页面ajax请求

使jQuery响应:js

解析错误无效的 XML:601

对Ajax请求做Session过期判断