如何解决当提供者为 Auth0 时,next-auth 登录失败并出现 oauth_get_access_token_error 和 callback_oauth_error 错误
在带有用于通过 Auth0 授权的 next-auth 库的 NextJS 应用程序上,我在授权流程中遇到错误:
[next-auth][error][oauth_get_access_token_error] [
{
statusCode: 401,data: '{"error":"access_denied","error_description":"Unauthorized"}'
},undefined,undefined
]
https://next-auth.js.org/errors#oauth_get_access_token_error
[next-auth][error][oauth_get_access_token_error] [
{
statusCode: 401,'auth0','HRLMyC9s88eIttwR'
]
https://next-auth.js.org/errors#oauth_get_access_token_error
[next-auth][error][callback_oauth_error] {
statusCode: 401,"error_description":"Unauthorized"}'
}
https://next-auth.js.org/errors#callback_oauth_error
所有引用的错误都没有任何详细信息。
auth0 中的应用程序设置实际上是基础,只有 Allowed Callback URLs
设置为 http://localhost:3000/api/auth/callback/auth0
,因为 auth0 登录正在抱怨它。
./api/auth/...[nextauth]
文件中的 next-auth 配置如下:
...
[
NextAuthProviders.Auth0({
clientId: process.env.NEXTAUTH_AUTH0_CLIENT_ID,clientSecret: process.env.NEXTAUTH_AUTH0_CLIENT_SECRET,domain: process.env.NEXTAUTH_AUTH0_DOMAIN,})
],debug: true,...
可能是什么配置错误?是否可以通过本地主机上的 next-auth 提供程序运行 auth0?
解决方法
您是否尝试将 The next-auth 配置文件名从 ...[nextauth]
更改为 [...nextauth]
,它应该类似于 ./api/auth/[...nextauth]
,只是跳跃这是问题所在。
如果没有,正如我在评论中提到的:
我已经在没有任何自定义配置的情况下尝试过使用 next-auth-example,并且无需设置自定义服务器来运行我的 下一个带有 https 且没有本地 SSL 配置的应用程序,它仍然有效 Auth0 没问题。
但我一开始遇到了问题,尝试了一下:
- 在 Windows 中启用 TLS 1.3 支持
- 在 chrome 上禁用 QUIC 协议
- 清除了我的网络历史记录/缓存
然后它开始工作。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。