javascript - jQuery Basic Auth 发送凭据时出错

标签 javascript jquery

有一个问题,我“认为”凭据没有被设置,即使在 beforeSend 中指定了凭据。所有设置都是动态的,包括 header 和基本身份验证(用于 api 文档)。

基本身份验证正在顺利传递,即:“Basic 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 

最佳答案

事实证明,这是浏览器预检请求(选项)不包含身份验证 header 信息的问题,因此 java 服务失败。通过捕获并忽略选项请求解决了该问题。

关于javascript - jQuery Basic Auth 发送凭据时出错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25202848/

相关文章:

jquery - 使用 jquery 在页面加载时突出显示 jquery TreeView 中的默认节点

javascript - HTML Accordion 50/50 分屏

javascript - jQuery .remove() 不工作,而其他内置函数是

javascript - AJAX POST 请求的行为类似于 GET?

javascript - 如果某个单元格不为空,如何更改 Slickgrid 中的行背景颜色?

javascript - 在JQuery中,如何仅根据一个表单输入的值显示错误?

Javascript 正则表达式 - 捕获前面有另一个字符串的字符串

javascript - google map javascript api v3 不适用于 xcode 7 构建的应用程序

javascript - 在不影响占位符的情况下增加密码输入字符大小

javascript - 如何在 IE 中刷新网页而不让浏览器询问确认消息