微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Angularjs之如何在跨域请求中传输Cookie的方法

一般情况我们在使用WebApi之类的技术时,都会遇到跨域的问题,这个只需要在服务端做一下处理即可。

如果这些GET或POST请求不需要传递Cookie数据的话,就没什么问题了,但如果需要,那么会发现 虽然已经处理了跨域请求的问题,但后台始终无法获取到Cookie。

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

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

后台代码

rush:js;"> Response.Headers.Add("Access-Control-Allow-Credentials","true");

前台代码

rush:js;"> $http.post("http://a.domain.com/Api/Product",{ productId: 3 },{ withCredentials: true,params: { name: "Ray" },headers: {'Authorization':"这个不重要"} }).success(function (data) { //Todo });

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

rush:js;"> angular.module("app").config(function ($httpProvider) { $httpProvider.defaults.withCredentials = true; $httpProvider.defaults.headers.common['Authorization'] = "89757"; })

如果使用jQuery,则是这样子的

rush:js;"> $.ajax({ type: "POST",url: "http://a.domain.com/Api/Product",xhrFields: { withCredentials: true },success: function (data) { console.log(data) },error: function (data) { console.error(data) } })

撇开Cookie跨域传输的问题,angularjs的跨域POST请求与jQuery有些区别:

jQuery跨域与本域的区别仅仅是请求头信息的变化;

angularjs跨域后,会变成两次请求,第一次的Request Method是OPTIONS,这里有个概念叫preflight,这里不谈。

第一次请求到服务器后,会针对请求的下面三项进行赋值

  1. Access-Control-Allow-Origin
  2. Access-Control-Allow-Methods
  3. Access-Control-Allow-Headers"

浏览器接收到返回信息后,会再次发送请求,这次的Request Method是POST,这回就跟普通本域请求一样了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

原文地址:https://www.jb51.cc/js/32060.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐