angularjs - $http post 请求未添加指定的 header

标签 angularjs cors jetty preflight jetty-8

我正在使用 $http 向我的服务器发出请求到我的后端以进行登录,但即使在正确指定 header 之后,它也会预检我的请求,并且还添加了我从未询问过的 header 。

这是我向服务器发出的请求

$http({
       method: 'POST',
       url: 'http://localhost:8080/SignInMainServlet',
       data: $httpParamSerializerJQLike({
                login_source: source,
                accessToken: code,
                referrer_code: referral_id
            }),
       headers: { 'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8' }
     });

这是我处理请求的服务器代码

protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
    // TODO Auto-generated method stub
    REFERRAL_CODE_COUNT++;
    String referrer_code=request.getParameter("referrer_code");
    String login_source=request.getParameter("login_source");
    String accessToken=request.getParameter("accessToken");

    SignInMainManager m = new SignInMainManager(accessToken, referrer_code, login_source,REFERRAL_CODE_COUNT);
    String result = m.signIn();


    response.setContentType("text/html");  

    response.addHeader("Access-Control-Allow-Origin","*");
    response.addHeader("Access-Control-Allow-Methods","POST");
    response.addHeader("Access-Control-Allow-Headers","Content-Type");

    PrintWriter out = response.getWriter(); 


    out.println(result);
    out.close();//closing the stream 


}

这是浏览器控制台显示的错误

XMLHttpRequest cannot load http://localhost:8080/SignInMainServlet. Response to preflight request doesn't pass access control check: No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost:3000' is therefore not allowed access.

这就是 xhr 调用的请求、响应和常规在 chrome 上的样子

// Request//
OPTIONS /SignInMainServlet HTTP/1.1
Host: localhost:8080
Connection: keep-alive
Access-Control-Request-Method: POST
Origin: http://localhost:3000
User-Agent: Mozilla/5.0 (Linux; Android 6.0; Nexus 5 Build/MRA58N) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/56.0.2924.76 Mobile Safari/537.36
Access-Control-Request-Headers: authorization
Accept: */*
Referer: http://localhost:3000/
Accept-Encoding: gzip, deflate, sdch, br
Accept-Language: en-GB,en-US;q=0.8,en;q=0.6

//Response//
HTTP/1.1 200 OK
Date: Sun, 05 Feb 2017 10:44:57 GMT
Allow: POST, TRACE, OPTIONS
Content-Length: 0
Server: Jetty(8.1.14.v20131031)

//General//
Request URL:http://localhost:8080/SignInMainServlet
Request Method:OPTIONS
Status Code:200 OK
Remote Address:127.0.0.1:8080

卡在这里一天了。真的需要帮助!!

最佳答案

我发现您正在使用身份验证。我相信您的预检请求不起作用,因为您错过了 CORS 中的一些配置。这样你的飞行前请求就会中止。像这样设置你的 CORS:

response.addHeader("Access-Control-Allow-Origin","*");
response.addHeader("Access-Control-Allow-Methods","GET, POST, OPTIONS");
response.addHeader("Access-Control-Allow-Credentials", "true");
response.addHeader("Access-Control-Allow-Headers","Origin, Content-Type, X-Auth-Token , Authorization");

最重要的是,您只配置了一个 protected void doPost() 监听器。这样,预检 OPTIONS 请求就不会配置 CORS,因为它监听 doOptions()。添加 doOptions() 监听器并将您的 CORS 配置放入其中,或全局定义您的 响应 CORS。

有点像这样:

protected void doOptions(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

    response.addHeader("Access-Control-Allow-Origin","*");
    response.addHeader("Access-Control-Allow-Methods","GET, POST, OPTIONS");
    response.addHeader("Access-Control-Allow-Credentials", "true");
    response.addHeader("Access-Control-Allow-Headers","Origin, Content-Type, X-Auth-Token , Authorization");

    PrintWriter out = response.getWriter();
    out.close();//closing the stream
}

关于angularjs - $http post 请求未添加指定的 header ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42051236/

相关文章:

异步调用后,AngularJS 范围未在 View 中更新

javascript - 如何在不使用 $watch 的情况下在多个 Controller 上保持服务数据相同?

c# - 在 ASP.NET Core 3.1 中处理多环境的 CORS 策略

java - Jetty - WebSocket.sendMessage(String data) 和 void sendMessage(byte frame,String data) 有什么区别?

java - jetty 配置错误

javascript - 将计算值传递给 ng-model

javascript - AngularJS 和异步操作

即使没有 application/json 内容类型,AngularJS 也会继续执行预检请求

apache - 允许对 http 和 https 的跨源请求

java - 如果 start() 出现异常,则终止 Jetty 服务器线程池