千家信息网

Angular如何通过CORS实现跨域方案

发表于:2025-11-13 作者:千家信息网编辑
千家信息网最后更新 2025年11月13日,这篇文章给大家介绍Angular如何通过CORS实现跨域方案,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。就拿iframe来说作为一个前端工程师,我极为讨厌iframe这种东西.
千家信息网最后更新 2025年11月13日Angular如何通过CORS实现跨域方案

这篇文章给大家介绍Angular如何通过CORS实现跨域方案,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

就拿iframe来说作为一个前端工程师,我极为讨厌iframe这种东西.它不光增加了性能上的高负荷,同时也不利于掌控。

在Angular应用中实现跨域的方式相对简单,基本上通过两种方式即可.一种是JSONP,另一种是通过CORS.前者是相对比较老的手法,后者我感觉更加给力一点,所以主要说一下Angular如何与CORS配合跨域.

能不使用JSONP就尽量不使用,这是着手于Angular跨域的一个原则吧.不管怎么说,script的标签嵌入感觉还是low了点.

Angular推崇的时前后端分离,所以跨域由哪一方实现成为一个问题.这个就不得不说前端技术上的局限性,即使是相对好用的JSONP对于非GET请求也是无能为力的,因为它本质上还是通过script去get一些资源.

JSONP这种只能GET的限制,在Angular推崇RESTful风格接口的API场景下,就完全制约了它的使用,总不能弃POST和PUT那些不管.并且JSONP的错误处理很弱,不尽人意.总之前端实现跨域都有各种各样的局限性,又比如像document.domain则只能用于主域相同,子域不同的情况.

所以总结而言,虽然前端有多种方式处理跨域,但是多而不精,缺点都比较明显.相对而言更好的方式是通过后端参与处理,这样做不仅适用性更强,同时前端只要发送正常的Ajax请求即可.这样的技术叫做CORS.

Cross-Origin Resource Sharing跨域资源共享,应该算是现在最为推荐的跨域处理方案.不仅适用于各种Method,而且更加方便和简单.当然了,这么吊的东西只有现代浏览器支持,IE8一下的老古董就不要想了.

CORS实现原理

虽然通过CORS实现跨域基本上完全由后端实现,不过身为一个给力的前端.还是要掌握一下这一原理,以便当你遇到不靠谱的后端时,不至于...你懂得

CORS的本质让服务器通过新增响应头Access-Control-Allow-Origin,通过HTTP方式来实现资源共享,让每个请求的服务直接返回资源.它使用了HTTP交互方式来确定请求源是否有资格请求该资源,并且通过设置HTTP Header来控制访问资源的权限.

具体的过程是这样的前端发送一个正常的请求:

$http.get('www.cros.com/api/data',{params:{    name: '顽Shi' }})

后端设置一下response的header:

Access-Control-Allow-Origin: "*" Access-Control-Allow-Methods: "GET" Access-Control-Max-Age: "60"

然后你观察一下浏览器的行为会发现有趣的事,浏览器在没有你干预的情况下,发现这是一个跨域请求.所以它没有直接发送GET请求,而是发送了一个OPTIONS请求询问是否可以跨域访问该资源,这个过程我们可以称之为"预检".

然后我们看到OPTIONS的response返回了类似下面的信息:

HTTP/1.1 200 OK    Date: Mon, 01 Dec 2013 01:15:39 GMT  Server: Apache/2.0.61 (Unix)  Access-Control-Allow-Origin: *  Access-Control-Allow-Methods: GET  Access-Control-Max-Age: 60  Content-Encoding: gzip  Content-Length: 0  Connection: Keep-Alive  Content-Type: text/text

这里的这几个Access头的内容就是服务器后端加上去的,它告诉了浏览器此后的60秒内,所有域都可以通过GET方法进行跨域访问该资源.然后浏览器自动再次发送了真正的GET请求,并返回对应的结果.

注意这一过程是浏览器自动实现的,这一点是不是非常棒.一些header信息的设置如下:

Access-Control-Allow-Origin:  | * // 授权的源控制  Access-Control-Max-Age:  // 授权的时间  Access-Control-Allow-Credentials: true | false // 控制是否开启与Ajax的Cookie提交方式  Access-Control-Allow-Methods: [, ]* // 允许请求的HTTP Method  Access-Control-Allow-Headers: [, ]* // 控制哪些header能发送真正的请求

这里还有一处需要前端工程师协作的地方就是cookie的传递,默认情况下通过CORS这样的方式是不会传递cookie.一般强制性将cookie添加到header的做法,也会被浏览器拒绝并报错.上面看到了在服务器端会通过添加一个response头,Access-Control-Allow-Credentials来控制是否允许Cookie的提交.

在Angular中我们需要进行一些设置达到目的:

$http.post(url, {withCredentials: true, ...})  // 或者  $http({withCredentials: true, ...}).post(...)  // 或者  .config(function ($httpProvider) {    $httpProvider.defaults.withCredentials = true;  }

如果是jQuery则要设置如下:

$.ajax("www.cros.com/api/data", {    type: "GET",    xhrFields: {      withCredentials: true   },    crossDomain: true,    success: function(data, status, xhr) {    }  });

CORS的过程描述完毕,在网上找到一张图片:

CORS的分类

如果仔细观察浏览器的行为会发现,并不是所有的跨域请求都会发送OPTIONS请求.是不是有些奇怪,这就涉及到CORS的分类,简单请求和复杂请求.

HTTP的header通常包含下面这些内容:

Accept  Accept-Language  Content-Language  Last-Event-ID  Content-Type的值仅是下列之一:                       application/x-www-form-urlencoded                       multipart/form-data                       text/plain

HTTP方法是HEAD,GET,POST之一,同时HTTP的header包含如上面所示.任何一个不满足这两种要求的请求,都是复杂请求.比如发送PUT,DELETE等HTTP动作,或者Content-Type: application/json的内容.

只有复杂请求包含"预检"这一动作,另外Access-Control-Max-Age应该也会影响OPTIONS请求的发送.

关于Angular如何通过CORS实现跨域方案就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

前端 方式 浏览器 资源 浏览 内容 控制 过程 处理 服务 方案 复杂 同时 情况 服务器 还是 东西 信息 动作 原理 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 梦幻西游手游万磁王什么服务器 江苏综合软件开发定制价格 数据库需要懂什么 怎么启动服务器ftp ftp服务器 手机 服务器虚拟化的两种产品 网络安全知识简报 数据库三种模型关系是 重庆维普科技期刊数据库 软件开发人员素质要求 全国网络安全知识竞赛成绩查询 数据库统计各分数段人数 进口以太网串口服务器哪家好 小米主题一直服务器不可以用 贵阳雷达币服务器 qq聊天内容怎么看到服务器 腾讯云轻量服务器可以架设手游吗 变电站网络安全防护检测宣传 自建服务器好处 如何知道服务器的子网掩码 杭州云长网络技术郭磊 软件开发多久毕业 分离后的数据库找不到 全国网络安全知识竞赛成绩查询 p2p理财平台软件开发 网络安全普及测试题 软件开发的事件驱动模型包括 国内外数据库技术的差距 网络安全与社会治理课题 软件开发测试皮肤分类
0