遇到问题,我认为"即使在beforeSend中指定,也不会设置凭据。它的所有设置都是动态的,包括标题和基本身份验证(适用于api文档)。
基本身份验证正在通过,即:"基本XXXXXXXX"
服务器具有Access-Control-Allow-Origin" *"
var $button = $(this).button('loading'),
$parent = $(this).parents('.api-test-response:first'),
$data = $('.api-test-data',$parent),
headers = {};
$('.api-test-headers tr',$parent).each(function(){
if($('.header-toggle', this)[0].checked && $('input.api-test-header-key',this).val() != ""){
headers[$('input.api-test-header-key',this).val()] = $('input.api-test-header-value',this).val();
}
});
$.ajax({
async: false,
cache: false,
crossDomain: true,
headers: headers,
beforeSend: function(xhr) {
if(headers['Authorization']){
xhr.withCredentials = true;
xhr.setRequestHeader('Authorization', headers['Authorization']);
}
return true;
},
url: this.dataset.url,
method: this.dataset.method || 'get',
dataType: this.dataset.type || 'json',
data: $data[0] ? $data[0].value : '',
success: function(data, status, jqXHR){
$('pre', $parent).removeClass('hide').find('code').html( !data ? status : data instanceof Object ? syntaxHighlight(data) : data );
},
error: function(jqXHR, status, error){
$('pre', $parent).removeClass('hide').find('code').html( '<div class="badge badge-important">'+ jqXHR.status +'</div> ' + (jqXHR.responseText != '' ? jqXHR.responseText : status + ' ' + error) );
}
})
.always(function (jqXhr) {
$button.button('reset');
$("body").scrollspy('refresh');
})
Chrome出错:
OPTIONS URL 401 (Unauthorized)
XMLHttpRequest cannot load URL. Invalid HTTP status code 401
Response : No Authorisation Provided
答案 0 :(得分:1)
结果证明浏览器预检请求(选项)不包含auth标头信息,因此java服务失败。通过捕获和忽略选项请求解决了该问题。