javascript – 为什么我总是在jquery ajax的情况下得到401(未授权)错误

我在jquery中使用ajax.当我提交我的价值时,我每次都会收到此错误.请让我知道我哪里错了?

  <script>
    $(document).ready(function(){
      $("button").click(function(){
        $.ajax({
          url: 'url_path',
          data: { 
            user : {
              email : $('#email').val(), 
              password : $('#password').val()
            } ,
            vendor_identifier : '3231-43423-fdsdfs'
          },
          dataType: 'jsonp',
            //method: 'POST',
            type:'POST',
            success: function(msg) {
              var msg = $.parseJSON(msg);
              console.log(msg);
            }
          });
      });
    });
  </script>

解决方法:

在您的示例中,您似乎正在访问某些需要通过电子邮件和密码进行身份验证的API. 401 Unauthorized只是说远程服务器由于某种原因无法使用电子邮件和密码以及您随请求发送的vendor_identifier的组合来验证用户.

可能是API在Authorization HTTP标头中需要Basic Authentication形式的用户名(电子邮件)和密码.如果您使用的是JQuery> = 1.7.2,那么它将为您创建Authorization标头.

看到这个问题:How to use Basic Auth with jQuery and AJAX?

$(document).ready(function(){
  $("button").click(function(){
    $.ajax({
    url: 'url_path',
      data: { 
      user : {
        email : $('#email').val(), 
        password : $('#password').val()
      },
      vendor_identifier : '3231-43423-fdsdfs'
    },
    username: $('#email').val(),
    password: $('#password').val(),
    dataType: 'jsonp',
    success: function(msg) {
    var msg = $.parseJSON(msg);
    console.log(msg);
  }
});
上一篇:java – 在wicket中,结合wicket:与IAuthorizationStrategy的链接


下一篇:Spring Security与XACML集成(或任何其他基于策略的解决方案)