React Context 是关于向一个或多个子组件提供一些数据,而不必通过中间组件向下传递数据。没有用于在页面加载之间保持状态的内置机制,因此您需要为此使用另一个工具。
如果您还没有实现您的身份验证层,您将需要研究它是如何工作的。有许多策略可以保持该状态,即使仅在使用基于 cookie 的存储中也是如此。JWT(JSON Web Token)是一种流行的方法,它可以让您将签名的用户和客户端可读数据存储在 cookie 中,但需要做更多的工作来管理到期/续订并拥有更大的有效负载。假设这是您采用的方法,您可能会执行以下操作:
import React from "react";
import jwt from "jsonwebtoken"; // Add jsonwebtoken via npm/yarn
function getCookieValue(a) {
var b = document.cookie.match('(^|[^;]+)\\s*' + a + '\\s*=\\s*([^;]+)');
return b ? b.pop() : '';
}
const AUTH_PUBLIC_KEY = "your JWT public key here"
export const AuthContext = React.createContext();
export class AuthContextProvider extends React.Component {
state = {
authenticated: false,
userid: null,
};
componentDidMount() {
jwt.verify(getCookieValue("session"), AUTH_PUBLIC_KEY, (err, session) => {
if (!err && session.userid) {
this.setState({ userid: session.userid, authenticated: true })
}
})
}
// Important: REMOVE THIS AFTER TESTING/DEV
toggleLogin = () => {
this.setState(state => ({
authenticated: !state.authenticated,
userid: 2,
}));
}
render() {
return (
<AuthContext.Provider
value={{
...this.state,
toggleLogin: this.toggleLogin,
}}
>
{this.props.children}
</AuthContext.Provider>
);
}
}
这将在session
挂载 AuthContextProvider 时解析cookie 中的 JWT 令牌,并使用userid
存储在 JWT 中的值更新状态(如果存在)。
您可能希望App
使用此组件包装 Gatsby ,您可以从gatsby-browser.js
和gatsby-ssr.js
文件中执行此操作(如果您还没有它们,请在您的存储库的根目录中创建它们):
// gatsby-browser.js
import React from "react"
import AuthContextProvider from "components/AuthContextProvider"
export const wrapRootElement = ({ element }) =>
<AuthContextProvider>{element}</AuthContextProvider>
// gatsby-ssr.js
import React from "react"
export { wrapRootElement } from "./gatsby-browser"
您仍然需要处理生成 JWT 令牌(可能来自处理身份验证的后端),如果它尚未保存在 cookie 中,您可以从浏览器访问,您将需要在相关点处理该 cookie 的创建您的应用程序生命周期。