IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 网络协议 -> 同源、跨域、跨站、SameSite与withCredentials -> 正文阅读

[网络协议]同源、跨域、跨站、SameSite与withCredentials

同源策略(Same-origin policy)

用于限制一个origin的文档或者它加载的脚本如何能与另一个源的资源进行交互。它能帮助阻隔恶意文档,减少可能被攻击的媒介。
同源策略作为浏览器的安全基石,判断较严格。
同源定义:协议+主机名+端口 均一致
如:https: www.baidu.com 协议为https,https默认端口443,主机名为www.baidu.com[1]
https://zhidao.baidu.com/https://wenku.baidu.com/ 属于跨源(跨域)

跨域(cross-origin)

当一个请求url的协议、域名、端口三者之间的任意一个与当前页面url不同即为跨域**。
也就是说
违反同源策略即为跨域**

  • 跨域限制
    • 无法读取非同源网页的cookie、localstorage等
    • 无法接触非同源网页的DOM和js对象
    • 无法向非同源地址发送Ajax请求
  • 什么情况下需要解决跨域
    • 前后端分离开发时,部署至不同ip(域名)环境
    • 某些资源在其他服务器上
  • 解决跨域(常用方式)
    • Nginx反向代理
    • 后端添加CORS相关的允许跨域响应头:允许特定源或全部源,如php框架手动处理响应头或第三方插件完成
    • jsonp 通过script标签请求数据

跨站(cross-site)

cookies的“同站(Same Site)”:

Cookie的同源主要用于防止CRSF,Cookie的校验较宽松,Cookie只关注域名,忽略协议和端口,只要两个 URL 的 eTLD+1 相同即可,eTLD 表示有效顶级域名,注册于 Mozilla 维护的公共后缀列表(Public Suffix List)中,例如,.com、.co、.uk、.github.io 等。而 eTLD+1 则表示,有效顶级域名+二级域名,例如taobao.com等。
如:

  • www.taobao.com 和 www.baidu.com 是跨站,
  • www.a.taobao.com 和 www.b.taobao.com 是同站
  • a.github.io和b.github.io是跨站
  • 所以跨站即
    • 两个URL顶级域名和二级域名不同就是跨站(也称第三方(Third-party)),
    • 相同则是同站本方(First-party)。

可以看出Cookie的“同源”比浏览器同源条件会宽松一点。

如何检查请求是否为 “同站”,“同源”,或“跨站”

Chrome 发送请求时会附带一个 Sec-Fetch-Site HTTP Header 。截至2020年4月,还没有其他浏览器支持 Sec-Fetch-Site,这个 HTTP Header 将有以下值之一:

  • cross-site
  • same-site
  • same-origin
  • none

通过检查 Sec-Fetch-Site 的值,您可以确定请求是 “同站”,“同源” 还是 “跨站”。

CORS中的withCredentials 与 SameSite

  • withCredentials与SameSite都是针对Cookie跨站的属性,都与CSRF安全相关
  • 但针对同样的事,两者的态度事对立的,一个希望允许,一个希望限制
  • withCredentials可正对XHR;而same而samesite可针对xhr,也可包括a img iframe等等标签的引用http所相关的cookie
  • withCredentials很早在CORS标准中提出;sameSite在chrome v80中提出,v86中全量默认设置sameSite为Lax
  1. **withCredentials **
    1. 作用:允许跨域AJAX请求携带(发送)Cookie
    2. 基于CORS,使用条件:服务器需要显式返回Access-Control-Allow-Credentials头信息并只能设置为特定域名,不能设置为*
    3. 客户端开启:xhr.withCredentials = true;
    4. 默认情况,即使开启跨域,withCredentials默认值为false,没有设置为true时,请求仍然是不会发送Cookie的
    5. 更多见参考[1]
  2. SameSite
    1. 作用:该属性可分别限制整个页面中的每个http的Cookie跨站情况(即其意图和CSRF相关)
    2. 使用:HTTP响应头 Set-Cookie 的属性之一,
    3. 带来的问题:在chrome86以后的版本中,之前上线跨站的Cookie用不了,就是说SameSite的新规则会禁用
      1. 解决:使用https协议且响应头设置为SameSite=none;Secure 表示关闭Cookie同站规则,允许跨域发送Cookie

Origin指定的域名在许可范围内,服务器返回的响应,会多出几个头信息字段

Access-Control-Allow-Origin: *
Access-Control-Allow-Credentials: true
Access-Control-Expose-Headers: FooBar
Content-Type: text/html; charset=utf-8

原来的时候设置CORS后所有请求即可携带cookies,但是在Chrome80版本之后,跨站之后,Chrome默认SameSite=Lax将使得cookies不同源同样无法携带,并提示CORS,此时还需要后端在响应头如下配置即可禁用cookie的这个字段SameSite的规则

SameSite=None; Secure

两个都配置的响应头如下所示:

图片1-响应头信息

小结

  • http://society.people.com.cn/http://ent.people.com.cn/ 同站不同源(same-site, cross-origin)
  • a.github.io 和 b.github.io 是跨站,(注意是跨站),因为github.io属于公共后缀列表eTLD(见参考索引15),同站需要eTLD+1相同
  • 一般的需要跨域时的处理方法:
    • 同源时,cookie会自动读取与存储、发送
    • 跨域未跨站(同站)时:后端添加CORS响应头保证跨域请求正常,配合前端XHR.withCredentials=true即可正常发送cookie,如壳里巴巴管理后台
    • 跨域且跨站时(跨站一定跨域):必要时添加SameSite=none;Secure或者nginx反向代理解决cookie跨站问题

参考:

  1. 跨域和跨站的基本概念 - Alex Zhong
  2. 浏览器的同源策略-MDN
  3. 跨域资源共享CORS详解 - 阮一峰
  4. Cookie的SameSite属性 - 阮一峰
  5. 当CORS遇到SameSite - 掘金-科学划水_玄学编程
  6. SameSite Cookies - MDN
  7. 什么是跨域?出现原因及解决办法 - segmengfault-HZM_无止境
  8. 跨域资源共享(CORS)- MDN
  9. 同源策略 - Web安全笔记
  10. HTTP Cookies - MDN
  11. 浏览器同源策略问题 - Cookie访问限制 - 掘金-CoderJie
  12. Nginx常用语法
  13. SameSite那些事 - 知乎- 怡红公子
  14. 预测最近面试会考 Cookie 的 SameSite 属性 - 掘金 - 冴羽
  15. 如何区分两个地址是同站(Same site)还是跨站(Cross site)?- 掘金- zhangbao90s
  16. 前端跨域解决方案归纳整理-Jacky-Summer
  17. 什么是CSRF - CSDN-炎升

需要进一步整理的


  网络协议 最新文章
使用Easyswoole 搭建简单的Websoket服务
常见的数据通信方式有哪些?
Openssl 1024bit RSA算法---公私钥获取和处
HTTPS协议的密钥交换流程
《小白WEB安全入门》03. 漏洞篇
HttpRunner4.x 安装与使用
2021-07-04
手写RPC学习笔记
K8S高可用版本部署
mySQL计算IP地址范围
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:56:03  更:2022-03-08 22:58:02 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/4 18:38:18-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码