将自定义http标头添加到所有jQuery AJAX请求

Pet*_*ter 15 authentication ajax jquery xmlhttprequest http-headers

澄清一点:我没有任何问题在我的jQuery ajax调用中添加自定义标头,我希望自动将我的自定义标头添加到所有ajax调用中.

如果你看一下jquery $ .ajax自定义http头问题(不是我的问题),你会看到一个非常好的例子,说明如果手动为每个ajax调用实现代码的工作方式.

我想覆盖所有jQuery ajax调用的beforeSend.据jQuery的文档,我可以利用这样做jQuery.ajaxSetup() ,但有一个警告,说你可能不应该,可能会导致意外的行为,所有的东西.对于这种全局回调,他们建议使用.ajaxStart(). .ajaxStart()看起来很棒,除了它不公开XHR所以我可以添加标题.

我应该使用ajaxSetup添加beforeSend吗?有没有办法从ajaxStart访问XHR?其他选择?

use*_*654 27

预过滤器将是实现此目的的简单方法:

$.ajaxPrefilter(function( options ) {
    if ( !options.beforeSend) {
        options.beforeSend = function (xhr) { 
            xhr.setRequestHeader('CUSTOM-HEADER-KEY', 'CUSTOM-HEADER-VALUE');
        }
    }
});
Run Code Online (Sandbox Code Playgroud)

这样,除非特定请求覆盖beforeSend选项,否则所有请求都将获得自定义标头.

但请注意,您可以使用ajaxSetup实现相同的目标.警告的唯一原因是因为使用它会影响所有ajax请求(就像我的方法一样),如果特定请求不需要该选项集,可能会导致不需要的结果.我建议只使用ajaxSetup,毕竟它就是它的用途.

  • 您不需要修改`beforeSend`函数.jqXHR对象作为`$ .ajaxPrefilter(options,originalOptions,jqXHR)`函数中的参数的一部分公开.所以你可以在prefilter函数`jqXHR.setRequestHeader('CUSTOM-HEADER-KEY','CUSTOM-HEADER-VALUE')里面写一下; (4认同)

Aru*_*hny 15

你可以使用ajax全局事件ajaxSend()

$( document ).ajaxSend(function( event, jqxhr, settings ) {
    jqxhr.setRequestHeader(name, value)
});
Run Code Online (Sandbox Code Playgroud)

演示:小提琴