gpt4 book ai didi

javascript - 将 firebase 用户凭据 token 存储在本地或 session 存储上是否安全?

转载 作者:行者123 更新时间:2023-12-04 14:16:02 25 4
gpt4 key购买 nike

为了提高我的 React 应用程序在页面重新加载时的性能,我将用户凭据存储在本地存储中并在注销时清除它们。但是这些天用户经常不注销并且用户凭据可以长时间保留在本地存储中,我认为这会导致一些安全漏洞吗?我不是 Firebase 安全方面的专家,所以有人可以解释一下它是否安全吗?

firebase.auth().onAuthStateChanged(user=>{
if (user) {
localStorage.setItem('user', JSON.stringify(user));
} else {
localStorage.removeItem('user');
}
})

最佳答案

在大多数平台上,Firebase 身份验证 SDK 已经自动将用户的凭据存储在本地存储中,并在应用重新启动/页面重新加载时从那里重新加载。您在 onAuthStateChanged 之前仍然看到页面重新加载延迟的原因触发,是因为客户端检查服务器以查看凭据是否(仍然)有效。

当 Firebase 正在检查凭据时,能够在页面加载时立即采取行动的一种简单解决方法是自己在本地存储中存储有关上次已知身份验证状态的值,并使用它来确定您的初始操作。这基本上就是您对 user 所做的事情。反对你的问题。

没有错,只要你第一次明白 onAuthStateChanged火灾,数据可能与您存储的不同。通常不会,但可能会,这就是 Firebase 必须首先检查凭据的全部原因。

另请参阅我昨天对这个相关问题的回答:Firebase auth.currentUser is null when loading the page, user loaded when authstatechange called after some milli seconds of page load

关于javascript - 将 firebase 用户凭据 token 存储在本地或 session 存储上是否安全?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60170407/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com