如何解决登录后在哪里以及如何更改会话用户对象?
我有一个奇怪的问题,我不知道问题在哪里。我使用next-auth库在我的Next.js
应用中构建身份验证系统。
一切正常-我可以通过以下方法登录:检查google firebase
中是否存在提交凭据的帐户,session
的创建正确,但是初始化authorize
回调后,我通过了正确登录后,从google firestore
接收到的数据。用户对象包含整个数据,并且已将其转发。
然后,当我想从session
读取数据时,我之前传递的一些数据丢失了。
代码:
/ pages / api / auth / [... nextauth.js]
export default (req,res) =>
NextAuth(req,res,{
providers: [
Providers.Credentials({
name: 'Credentials',credentials: {
phone: { label: "Phone number",type: "text" },password: { label: "Password",type: "password" }
},authorize: async (loginData) => {
const { csrfToken,phone,password } = loginData;
// checking if there is account with these credentials
let res = await login({
phone,password: sha1(md5(password)).toString()
})
// 200 = OK
if(res.status == 200){
// collect account data
const user = {
phone,...res.data.info
}
// user object is created correctly,whole data is stored there
console.log('received account data from firestore',user)
return Promise.resolve(user);
}
else {
// wrong credentials
return Promise.resolve(null);
}
}
})
],callbacks: {
session: async (session,user) => {
console.log('data passed to object when signed in',user)
// user object there doesn't have all data passed before
return Promise.resolve(session)
}
},debug: false
})
控制台记录的对象:
received account data from firestore
{
phone: '123123123',id: 'w2zh88BZzSv5BJeXZeZX',email: 'jan@gmail.com',name: 'Jan',surname: 'Kowalski'
}
data passed to object when signed in
{
name: 'Jan',iat: 1603900133,exp: 1606492133
}
最好的是,对象(上方)始终具有相同的属性。我可以在authorize
回调中传递任何对象,但是在session
中,user
对象始终具有“名称,电子邮件,iat,exp”。唯一更改的是对象(名称,电子邮件)中这两个属性的值。 (其余属性-“电话,ID,姓氏”-丢失)。
在任何react组件中都有控制台记录的session
对象:
import {
signIn,signOut,useSession
} from 'next-auth/client'
const [ session,loading ] = useSession();
console.log(session)
Photo of console logged session object
我该怎么办?我必须在firestore
回调中分别从session
接收数据吗? Next.js
的服务器端呈现是否引起此问题?
解决方法
我自己解决了这个问题。
这个问题线程对我有很大帮助!
https://github.com/nextauthjs/next-auth/issues/764
下面是解释:
callbacks: {
jwt: async (token,user,account,profile,isNewUser) => {
// "user" parameter is the object received from "authorize"
// "token" is being send below to "session" callback...
// ...so we set "user" param of "token" to object from "authorize"...
// ...and return it...
user && (token.user = user);
return Promise.resolve(token) // ...here
},session: async (session,sessionToken) => {
// "session" is current session object
// below we set "user" param of "session" to value received from "jwt" callback
session.user = user.user;
return Promise.resolve(session)
}
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。