Angularjs 跨域cookie

阅读更多

一般情况我们在使用WebApi之类的技术时,都会遇到跨域的问题,这个只需要在服务端做一下处理即可。
如果这些GET或POST请求不需要传递Cookie数据的话,就没什么问题了,但如果需要,那么会发现 虽然已经处理了跨域请求的问题,但后台始终无法获取到Cookie。

跨域传输Cookie是需要后台和前台同时做相关处理才能解决的。

就好比一个握手会话,前台先表示,我的跨域请求是带有Cookie的;请求到了服务端,服务端表示可以接收跨域Cookie,成交(开始重新带着Cookie发起请求)

 

后台代码

response.setHeader("Access-Control-Allow-Origin", "http://localhost:63342");

response.setHeader("Access-Control-Allow-Credentials", "true");

response.setHeader("Access-Control-Allow-Methods","GET,POST"); 

response.setHeader("Access-Control-Allow-Headers", "Content-Type, *"); 

前端代码

$http.post("http://a.domain.com/Api/Product", { productId: 3 },

{ withCredentials: true, params: { name: "Ray" }, }).success(function (data) { //TODO });

 

这个是在单独的请求中设置,如果要在所有的请求中都应用该设置则要使用 $httpProvider

angular.module("app").config(function ($httpProvider) {

$httpProvider.defaults.withCredentials = true;

})

 

 

你可能感兴趣的:(Angularjs 跨域cookie)