同源与跨域

一、同源策略

1、同源(origin)

  • 同源:若地址里面的协议、域名和端口号相同则属于同源。
  • 以下是相对于 http://www.a.com:8080/test/index.html 的同源检测:

http://www.a.com/dir/page.html ----成功(http默认端口号位8080)

http://www.child.a.com/test/index.html ----失败,域名不同

https://www.a.com/test/index.html ----失败,协议不同

http://www.a.com:8089/test/index.html ----失败,端口号不同

2、同源策略

  • 同源策略是浏览器的一个安全功能,不同源的客户端脚本在没有明确授权的情况下,不能读写对方资源。所以a.com下的js脚本采用ajax读取b.com里面的文件数据是会报错的。
  • 不受同源策略限制的情况:

①页面中的链接,重定向以及表单提交是不会受到同源策略限制的。

②跨域资源的引入是可以的。但是js不能读写加载的内容。如嵌入到页面中的<script src="..."></script>,<img>,<link>,<iframe>等。

二、跨域

1.跨域:

只要协议、域名、端口号有一个不同就是跨域。

2.跨域的原因:

跨域问题来源于JavaScript的同源策略,即只有 协议+主机名+端口号(如存在)相同,则允许相互访问。为了防止某域名下的接口被其他域名下的网页非法调用,是浏览器对JavaScript施加的安全限制。也就是说JavaScript只能访问和操作自己域下的资源,不能访问和操作其他域下的资源。跨域问题是针对JS和ajax的,html本身没有跨域问题,比如a标签、script标签、甚至form标签(可以直接跨域发送数据并接收数据)等。

三、跨域问题解决方案

1、jsonp

利用script标签可跨域的特点,在跨域脚本中可以直接回调当前脚本的函数。

2、cors

服务器设置HTTP响应头中Access-Control-Allow-Origin值,解除跨域限制。

注意:这两个跨域方案都存在一个致命的缺陷,严重依赖后端的协助。

3、反向代理(Reverse Proxy):

前端独立就能解决的跨域方案。

指以代理服务器来接受internet上的连接请求,然后将请求转发给内部网络上的服务器,并将从服务器上得到的结果返回给internet上请求连接的客户端,此时代理服务器对外就表现为一个反向代理服务器。

四、在Express项目中解决跨域问题的方法

使用cors模块

  1. 安装cors模块:npm install cors
  2. 在app.js文件中配置cors
  • 导入cors模块:在app创建之前导入

  •  使用cors模块:在app创建之后,在配置路由路径之前

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值