如何解决赛普拉斯在Chrome无头模式下忽略X-Frame-Options
我正在构建一个Cypress测试,该测试针对另一个域上的Azure B2C租户使用@msal-browser PKCE身份验证登录到我的应用程序,这对我造成了x帧问题:
Refused to display 'https://somecrossdomainurl/oauth' in a frame because it set 'X-Frame-Options' to 'deny'.
我意识到跨域测试是针对赛普拉斯login best practices的-但是,我的身份验证方法使用的是PKCE,而不是隐式的授权流程,因此如果没有浏览器的交互,我就无法获得令牌。此外,轻度易碎风险是我愿意进行的实时集成测试的折衷方案,该测试实际上已登录到我的应用程序中。
我通过安装第三方扩展程序来使用the proposed workaround来忽略X-Frame标头,并且效果很好。当我尝试在--headless
模式下运行它时,问题就来了。 Chrome does not allow extensions to be installed in headless mode,因此对于CI环境而言,解决方法确实不可行。
除了对auth进行存根处理之外,我对如何实现此方法一无所知。鉴于已知的隐式流程漏洞和PKCE的兴起,赛普拉斯认为应该有一个解决方案。我是赛普拉斯的新手,所以肯定会缺少一些简单的东西吗?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。