Fer*_*tas 4 reactjs next.js next-auth
我无法使用 getToken 获取令牌:
这个变量没问题: NEXTAUTH_SECRET=secret NEXTAUTH_URL=http://localhost:3000
这是我的 [...nextauth].js - 我可以做 console.log(token) 并且效果很好
import NextAuth from "next-auth";
import GoogleProvider from "next-auth/providers/google";
...
jwt: {
secret: process.env.JWT_SECRET,
encryption: true,
},
secret: process.env.NEXTAUTH_SECRET,
callbacks: {
async redirect({ url, baseUrl }) {
return Promise.resolve(url);
},
async jwt({ token, user, account, profile, isNewUser }) {
return token;
},
async session({ session, user, token }) {
return session;
},
},
});
Run Code Online (Sandbox Code Playgroud)
API部分(我认为getToken效果不好):
import { getToken } from "next-auth/jwt";
const secret = process.env.NEXTAUTH_SECRET;
export default async (req, res) => {
const token = await getToken({ req, secret, encryption: true });
console.log(token);
if (token) {
// Signed in
console.log("JSON Web Token", JSON.stringify(token, null, 2));
} else {
// Not Signed in
res.status(401);
}
res.end();
};
Run Code Online (Sandbox Code Playgroud)
这可能是函数中的一个错误,但我让它工作的唯一方法是使用 getToken 获取原始 jwt 令牌,然后使用 jsonwebtoken 包来验证和解码它
import { getToken } from "next-auth/jwt";
import jwt from "jsonwebtoken";
Run Code Online (Sandbox Code Playgroud)
const secret = process.env.NEXT_AUTH_SECRET;
const token = await getToken({
req: req,
secret: secret,
raw: true,
});
const payload = jwt.verify(token, process.env.NEXT_AUTH_SECRET);
console.log(payload);
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
16977 次 |
最近记录: |