一个post产生了两个请求

我这里有一个跨域post请求,

var AjaxPost = (url, data, action ) => {

    let xhr = new XMLHttpRequest();
    xhr.open("POST", url, true);
    xhr.withCredentials = true
    xhr.setRequestHeader("Content-type", "application/json");
    xhr.onreadystatechange = () =>{
        if (xhr.readyState == 4 && xhr.status == 200) {
            //action是传入的callback
            action(JSON.parse(xhr.responseText))
        }
    }
    xhr.send(JSON.stringify(data))
}

export default AjaxPost

服务器用nginx做反向代理,配置如下

proxy_set_header Access-Control-Allow-Origin http://192.168.1.106:8080;
  add_header Access-Control-Allow-Headers X-Requested-With;
  add_header Access-Control-Allow-Methods GET,POST,OPTIONS;

但是post方式发送一个json数组到服务器却发现同样的路径不管在nginx的log和被代理的node服务器里看都是收到两个请求,一个是OPTIONS方法,一个是正常的POST方法,不知道是什么原因

阅读 4.4k
2 个回答

前两天我也碰到了这样的事情。
问题在于浏览器的跨域

MDN:HTTP access control

这个资源还是比较权威的。推荐阅读

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题