我们正在使用 AngularJS 和 Java Servlet 开发 RESTful Web 服务。
当用户登录时,我们的后端向前端发送一个“Set-Cookie” header 。在 Angular 中,我们通过 $cookies
(ngCookie - 模块)访问 header 并设置它。
现在用户已经登录,他可以删除一些东西。因此,前端向后端发送 GET 请求。因为我们在不同的领域工作,所以我们需要设置一些 CORS header ,并且 Angular 在实际 GET 请求之前执行 OPTIONS 请求:
OPTIONS 请求:
GET 请求
我们通过 $http 模块在 Angular 中执行此操作,但它不会发送包含 JSESSIONID
的 cookie。
如何让 Angular 发送 cookie?
最佳答案
在您的配置中,DI $httpProvider
然后将 withCredentials 设置为 true:
.config(function ($httpProvider) {
$httpProvider.defaults.withCredentials = true;
//rest of route code
})
关于 angularjs withCredentials 的信息:http://docs.angularjs.org/api/ng.$http
其中链接到 mozilla 文章:https://developer.mozilla.org/en-US/docs/HTTP/Access_control_CORS?redirectlocale=en-US&redirectslug=HTTP_access_control#section_5
关于html - $http 不在请求中发送 cookie,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17064791/