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);
  }
});

相关文章

$.AJAX()方法中的PROCESSDATA参数 在使用jQuery的$.ajax()方...
form表单提交的几种方式 表单提交方式一:直接利用form表单提...
文章浏览阅读1.3k次。AJAX的无刷新机制使得在注册系统中对于...
文章浏览阅读1.2k次。 本文将解释如何使用AJAX和JSON分析器在...
文章浏览阅读2.2k次。/************************** 创建XML...
文章浏览阅读3.7k次。在ajax应用中,通常一个页面要同时发送...