大概新年新气象吧,大家复工之后都追求一个“新”,不少用户升级到了Chrome 80,然后发现登入成功之后总是重定向回单点登录的统一登录页,然后头秃的我感觉头上更凉了。
生产环境出了问题,肯定得赶紧寻找问题根源啊。(三步走路子)
cookie
失效的问题,于是远程用户,发现浏览器cookie
设置正常,域名下cookie
也有值,但就是带不过去后台,于是开始怀疑跨域出了问题。Nignx
配置,CORS
配置正常,那就不是后台的问题,应该是浏览器的锅。在Chrome 80版本中,Chrome会将没有声明SameSite
值的cookie
默认设置为SameSite=Lax
。只有采用SameSite=None; Secure
设置的cookie
可以从外部访问,前提是通过安全连接(即HTTPS
)访问。
SameSite
又是个啥?(T︵T,为啥那么多我不知道的东西),哎,慢慢道来。
SameSite
SameSite
是Cookie
中的一个属性,它用来标明这个 cookie
是个“同站 cookie
”,“同站 cookie
” 只能作为第一方cookie
,不能作为第三方cookie
,因此可以限制第三方Cookie
,解决CSRF
的问题。不知道CSRF
的看着这个。早在Chrome 51中就引入了这一属性,但是不会默认设置,所以相安无事。
第三方Cookie:由当前a.com
页面发起的请求的URL
不一定也是a.com
上的,可能有b.com
的,也可能有c.com
的。我们把发送给a.com
上的请求叫做第一方请求(first-party request
),发送给b.com
和c.com
等的请求叫做第三方请求(third-party request
),第三方请求和第一方请求一样,都会带上各自域名下的cookie
,所以就有了第一方cookie
(first-party cookie
)和第三方cookie
(third-party cookie
)的区别。上面提到的CSRF
攻击,就是利用了第三方cookie
可以携带发送的特点 。
“同站cookie
”不是根据同源策略判断,而是PSL(公共后缀列表),子域名可以访问父域名cookie
,但父域名无法访问子域名cookie
。
SameSite
总共有三个值:Strict
、Lax
、None
。以下内容引自阮一峰博客
Strict
Strict
最为严格,完全禁止第三方 Cookie
,跨站点时,任何情况下都不会发送 Cookie
。换言之,只有当前网页的 URL
与请求目标一致,才会带上 Cookie
。
Set-Cookie: CookieName=CookieValue; SameSite=Strict;
这个规则过于严格,可能造成非常不好的用户体验。比如像本人当前遇到的现象,cookie
带不过,等于一直没有登录状态,就会回到登录页。
Lax
Lax
规则稍稍放宽,大多数情况也是不发送第三方 Cookie
,但是导航到目标网址的 Get
请求除外。Chrome 80之后默认设置为该值。
Set-Cookie: CookieName=CookieValue; SameSite=Lax;
导航到目标网址的 GET
请求,只包括三种情况:链接,预加载请求,GET
表单。详见下表。
请求类型
示例
正常情况
Lax
链接
发送 Cookie
发送 Cookie
预加载
<link rel=“prerender” href="…"/>
发送 Cookie
发送 Cookie
GET
表单
<form method=“GET” action="…">
发送 Cookie
发送 Cookie
POST
表单
<form method=“POST” action="…">
发送 Cookie
不发送
iframe
<iframe src="…"></iframe>
发送 Cookie
不发送
AJAX
$.get("…")
发送 Cookie
不发送
Image
<img src="…">
发送 Cookie
不发送
设置了Strict
或Lax
以后,基本就杜绝了CSRF
攻击。当然,前提是用户浏览器支持 SameSite
属性。
None
浏览器会在同站请求、跨站请求下继续发送cookies,不区分大小写。网站可以选择显式关闭 SameSite
属性,将其设为 None
,同时必须设置 Secure
属性(表示Cookie
只能通过 HTTPS
协议发送,HTTP
协议不会发送),否则无效。
下面为无效响应头:
Set-Cookie: widget_session=abc123; SameSite=None
下面为有效响应头:
Set-Cookie: widget_session=abc123; SameSite=None; Secure
本人项目中,采用单点登录,在验证登录状态时存在跨域,即采用JSONP
的方式获取JWT
等相关信息,然后写入本项目域名下的cookie
中,满足Lax
属性值表单中的AJAX
请求,所以不会发送Cookie
。
准确定位到问题,就好办了。这里想到了两种解决方法:
SameSite
属性,按照上述有效响应头设置登录接口的响应头即可(本人目前采取的该方法)。直接配置Nginx也行,最先采用的这种方法。//...
response.setHeader(name: "Set-Cookie", value: "_u=xxxx; Path=/Login; SameSite=None; Secure")
//...
最后响应头如下:
2. 浏览器显式关闭该功能。(不推荐,这个功能还是蛮有用的)
chrome://flags/
SameSite by default cookies
和Cookies without SameSite must be secure
Disable
Original url: Access
Created at: 2020-09-08 16:07:34
Category: default
Tags: none
未标明原创文章均为采集,版权归作者所有,转载无需和我联系,请注明原出处,南摩阿彌陀佛,知识,不只知道,要得到
java windows火焰图_mob64ca12ec8020的技术博客_51CTO博客 - 在windows下不可行,不知道作者是怎样搞的 监听SpringBoot 服务启动成功事件并打印信息_监听springboot启动完毕-CSDN博客 SpringBoot中就绪探针和存活探针_management.endpoint.health.probes.enabled-CSDN博客 u2u转换板 - 嘉立创EDA开源硬件平台 Spring Boot 项目的轻量级 HTTP 客户端 retrofit 框架,快来试试它!_Java精选-CSDN博客 手把手教你打造一套最牛的知识笔记管理系统! - 知乎 - 想法有重合-理论可参考 安宇雨 闲鱼 机械键盘 客制化 开贴记录 文本 linux 使用find命令查找包含某字符串的文件_beijihukk的博客-CSDN博客_find 查找字符串 ---- mac 也适用 安宇雨 打字音 记录集合 B站 bilibili 自行搭建 开坑 真正的客制化 安宇雨 黑苹果开坑 查找工具包maven pom 引用地 工具网站 Dantelis 介绍的玩轴入坑攻略 --- 关于轴的一些说法 --- 非官方 ---- 心得而已 --- 长期开坑更新 [本人问题][新开坑位]关于自动化测试的工具与平台应用 机械键盘 开团 网站记录 -- 能做一个收集的程序就好了 不过现在没时间 -- 信息大多是在群里发的 - 你要让垃圾佬 都去一个地方看难度也是很大的 精神支柱 [超级前台]sprinbboot maven superdesk-app 记录 [信息有用] [环境准备] [基本完成] [sebp/elk] 给已创建的Docker容器增加新的端口映射 - qq_30599553的博客 - CSDN博客 [正在研究] Elasticsearch, Logstash, Kibana (ELK) Docker image documentation elasticsearch centos 安装记录 及 启动手记 正式服务器 39 elasticsearch 问题合集 不断更新 6.1.1 | 6.5.1 两个版本 博客程序 - 测试 - bug记录 等等问题 laravel的启动过程解析 - lpfuture - 博客园 OAuth2 Server PHP 用 Laravel 搭建带 OAuth2 验证的 RESTful 服务 | Laravel China 社区 - 高品质的 Laravel 和 PHP 开发者社区 利用Laravel 搭建oauth2 API接口 附 Unauthenticated 解决办法 - 煮茶的博客 - SegmentFault 思否 使用 OAuth2-Server-php 搭建 OAuth2 Server - 午时的海 - 博客园 基于PHP构建OAuth 2.0 服务端 认证平台 - Endv - 博客园 Laravel 的 Artisan 命令行工具 Laravel 的文件系统和云存储功能集成 浅谈Chromium中的设计模式--终--Observer模式 浅谈Chromium中的设计模式--二--pre/post和Delegate模式 浅谈Chromium中的设计模式--一--Chromium中模块分层和进程模型 DeepMind 4 Hacking Yourself README.md update 20211011
Laravel China 简书 知乎 博客园 CSDN博客 开源中国 Go Further Ryan是菜鸟 | LNMP技术栈笔记 云栖社区-阿里云 Netflix技术博客 Techie Delight Linkedin技术博客 Dropbox技术博客 Facebook技术博客 淘宝中间件团队 美团技术博客 360技术博客 古巷博客 - 一个专注于分享的不正常博客 软件测试知识传播 - 测试窝 有赞技术团队 阮一峰 语雀 静觅丨崔庆才的个人博客 软件测试从业者综合能力提升 - isTester IBM Java 开发 使用开放 Java 生态系统开发现代应用程序 pengdai 一个强大的博主 HTML5资源教程 | 分享HTML5开发资源和开发教程 蘑菇博客 - 专注于技术分享的博客平台 个人博客-leapMie 流星007 CSDN博客 - 舍其小伙伴 稀土掘金 Go 技术论坛 | Golang / Go 语言中国知识社区
最新评论