在使用iframe angular-oauth2-oidc中使用会话存储时给出domexception的错误:无法读取sessionstorage'
我正在使用 angular-oauth2-oidc 软件包进行身份验证,并且我的应用程序用于iFrame,因此当第三方cookie被阻止时,它将出现以下错误。
core.js:6241 ERROR DOMException: Failed to read the 'sessionStorage' property from 'Window': Access is denied for this document.
at Object.createDefaultStorage [as useFactory] (http://localhost:4200/vendor.js:81943:5)
at Object.factory (http://localhost:4200/vendor.js:30286:28)
at R3Injector.hydrate (http://localhost:4200/vendor.js:30153:63)
at R3Injector.get (http://localhost:4200/vendor.js:29903:33)
at injectInjectorOnly (http://localhost:4200/vendor.js:15722:33)
at Module.ɵɵinject (http://localhost:4200/vendor.js:15732:57)
at **Object.OAuthService_Factory [as factory]**
当我从代码中删除会话存储时,我收到了相同的错误消息。 我的问题是Angular-Oauth-oidc软件包以某种方式使用会话存储? 除了允许第三方饼干外,我该如何克服这种情况,因为我不能依靠使用此解决方案的人允许第三方饼干?
I am using the angular-oauth2-oidc package for authentication and my application is used in iFrame, so when the third-party cookies are blocked, it will give the below error.
core.js:6241 ERROR DOMException: Failed to read the 'sessionStorage' property from 'Window': Access is denied for this document.
at Object.createDefaultStorage [as useFactory] (http://localhost:4200/vendor.js:81943:5)
at Object.factory (http://localhost:4200/vendor.js:30286:28)
at R3Injector.hydrate (http://localhost:4200/vendor.js:30153:63)
at R3Injector.get (http://localhost:4200/vendor.js:29903:33)
at injectInjectorOnly (http://localhost:4200/vendor.js:15722:33)
at Module.ɵɵinject (http://localhost:4200/vendor.js:15732:57)
at **Object.OAuthService_Factory [as factory]**
When I removed the session storage from the code, I got the same error message.
My question is angular-oauth-oidc package somehow use the session storage?
How can I overcome this situation except allow the third-party cookies because I can not rely on a person using this solution to allow the third-party cookies?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
是的,浏览器中的限制将做到这一点。如果您的应用程序无法使用
SessionStorage
,则库将无法将任何令牌保存在默认存储机制中。您需要 oauthstorage 并创建一个内存实现或其他一些与父框架协调的实现,以确保库中的数据被持续存在。
自定义存储看起来像这样:
然后
通过Angular的DI系统提供
。Yup, restrictions in browsers will do this. If
sessionStorage
is not available to your application the library will not be able to save any tokens in the default storage mechanism.You need to create a custom
OAuthStorage
and create an in-memory implementation or some other implementation that coordinates with the parent frame to ensure data from the library gets persisted.Custom storage could look like this:
And then
provide
it through Angular's DI system.