我需要在 getServerSideProps 函数中访问 cookie 以验证用户,但我无法访问任何 cookie
export async function getServerSideProps(context) {
const cookies = nookies.get(context); // get undefined
const { req, res } = context;
const token = context.req.headers.cookie; // get undefined
// req.cookies is also undefined
console.log(token);
return {
props: {
cookies:cookies,
}
};
}
export default MainPage;
我可以在浏览器中看到 cookie,如果它是 httpOnly、secure 或其他任何东西,它都没有区别。 这是我设置 cookie 的代码的一部分,但我认为这不是问题
res.setHeader("Set-Cookie",
cookie.serialize("userToken", token, { maxAge: 43200,}));
res.status(200).send(payload);
答案 0 :(得分:0)
好的,我想通了,万一其他人为此苦苦挣扎,我只需将创建时的 cookie 路径设置为“/”,如下所示:
res.setHeader("Set-Cookie",
cookie.serialize("userToken", token, {
maxAge: 43200,
path: "/",
httpOnly: true,
secure: process.env.NODE_ENV !== "development",
})
);