来自子域A的Cookie未发送到子域B

如何解决来自子域A的Cookie未发送到子域B

我有一个托管在dev.subdomain.mydomain.com上的前端Angular应用程序。该应用程序向dev.api.mydomain.com上托管的.net CORE API发出HTTP请求。我的角度应用程序具有与之关联的会话cookie,该会话cookie具有以下安全属性

Secure=true
HttpOnly=true
SameSite=None
Domain=.mydomain.com

我希望在每次请求时都将cookie发送到后端服务器,但由于某种原因,请求会在没有cookie的情况下发送。

添加一个角度拦截器,将withCredentials选项添加到外发请求中

req = req.clone({
       headers: req.headers.set('Content-Type','application/json'),withCredentials: true
});

但是那也没有帮助。在Chrome和Firefox中进行了测试,结果相同。

Update:我注意到cookie确实是在初始的http请求上发送的(去服务器获取有角度的应用程序),但是使用httpClient的ajax请求却没有与cookie一起发送

Update 2:我已经设置了我的API,以便在飞行前响应中包含以下标头:

Access-Control-Allow-Origin: https://dev.subdomain.mydomain.com
Access-Control-Allow-Credentials: true
Access-Control-Allow-Headers: content-type,withcredentials
Access-Control-Allow-Methods: GET

仍然没有发送Cookie。

解决方法

如果前端和API均位于*.mydomain.com下,则它们应计为同一站点,这意味着SameSite=Lax应该没问题。

如果您查看Chrome开发者工具,则“问题”标签应告诉您任何受SameSite默认设置影响或没有正确设置属性的Cookie。

在“网络”选项卡中,如果您选择一个单独的请求,那么您也可以在其中查看Cookies子面板,并启用“显示过滤出的请求Cookies”以显示哪些cookie被删除。将鼠标悬停在它们上面还将提供说明原因的工具提示。

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

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?
Java在半透明框架/面板/组件上重新绘画。
Java“ Class.forName()”和“ Class.forName()。newInstance()”之间有什么区别?
在此环境中不提供编译器。也许是在JRE而不是JDK上运行?
Java用相同的方法在一个类中实现两个接口。哪种接口方法被覆盖?
Java 什么是Runtime.getRuntime()。totalMemory()和freeMemory()?
java.library.path中的java.lang.UnsatisfiedLinkError否*****。dll
JavaFX“位置是必需的。” 即使在同一包装中
Java 导入两个具有相同名称的类。怎么处理?
Java 是否应该在HttpServletResponse.getOutputStream()/。getWriter()上调用.close()?
Java RegEx元字符(。)和普通点?