我正在构建一个 GitHub Oauth 应用程序,我正在尝试使用用户点击 access_token
时获得的 Oauth sign in with Github
对 Octokit 进行身份验证。
我使用的 access_token
可以访问 repo
范围,但是当我尝试使用此令牌对 Octokit 进行身份验证时,我得到:HttpError: A JSON web token could not be decoded
这是我的代码:
let TOKEN = "<Token>"
const appOctokit = new Octokit({
auth: TOKEN
});
我也尝试过这样的身份验证:
const appOctokit = new Octokit({
authStrategy: createOAuthAppAuth,
auth: {
clientId: "<Client_ID>",
clientSecret: "<Client_Secret>",
},
});
但是当我这样做并尝试使用 octokit 删除问题时,我收到了 HttpError: Not Found
错误。
答案 0 :(得分:0)
身份验证流程有两个步骤:
该错误似乎表明问题与令牌有关;检查身份验证流程的步骤。不确定您是在构建前端还是服务器端。第一步是在用户浏览器中进行重定向;第二步是将请求发送到服务器,如果您还没有服务器来处理交换,则需要执行此操作。从 Github docs 中,令牌应类似于 gho_....
(40 个字符)。如果您使用此表单获取令牌,则身份验证流程应该是正确的。
获得令牌并使用 octokit-js 后,您instantiate Octokit 如下:
new Octokit({
auth: access_token,
baseUrl: 'https://api.github.com',
...otherProps
});