我正在使用节点
googleapis
库向 youtube 数据 API 发出请求。我首先使用 passport
passport-youtube-v3
库对用户进行身份验证。一切正常。我能够进行身份验证,并且可以向 youtube 数据 api 发出授权请求。但经过一定时间(大约 1-2 小时)后,凭据似乎已过期或变得无效,并且我收到以下错误:
{ Error: Invalid Credentials
at Request._callback (/Users/flavio/Code/BA/node_modules/google-auth-library/lib/transporters.js:85:15)
at Request.self.callback (/Users/flavio/Code/BA/node_modules/request/request.js:188:22)
at emitTwo (events.js:106:13)
at Request.emit (events.js:191:7)
at Request.<anonymous> (/Users/flavio/Code/BA/node_modules/request/request.js:1171:10)
at emitOne (events.js:96:13)
at Request.emit (events.js:188:7)
at IncomingMessage.<anonymous> (/Users/flavio/Code/BA/node_modules/request/request.js:1091:12)
at IncomingMessage.g (events.js:286:16)
at emitNone (events.js:91:20)
at IncomingMessage.emit (events.js:185:7)
at endReadableNT (_stream_readable.js:926:12)
at _combinedTickCallback (internal/process/next_tick.js:74:11)
at process._tickCallback (internal/process/next_tick.js:98:9)
code: 401,
errors:
[ { domain: 'global',
reason: 'authError',
message: 'Invalid Credentials',
locationType: 'header',
location: 'Authorization' } ] }
我了解身份验证令牌会在一段时间后过期。但根据文档,在不活动 6 个月之前,这种情况不会发生。此外,我不会发出过多可能导致令牌无效的请求。尽管如此,我还是尝试实现访问令牌的手动令牌刷新,如下所示:
const fetch = (user, ressource, operation, opts) => {
let oauth2Client = new OAuth2();
let client = google.youtube({ version: 'v3',auth: oauth2Client })[ressource][operation];
oauth2Client.credentials = {
access_token: user.youtube.token,
refresh_token: user.youtube.refreshToken
};
return new Promise((success, failure) => {
client(opts, function(err, data, response) {
if (err)
if(err.code === 401)
oauth2Client.refreshAccessToken(function(err, tokens) {
console.log(err);
});
else
failure(err);
if (data)
success(data);
});
});
}
我不确定我是否正确实现了这一点,或者这样做是否有意义。我收到以下错误:
{ Error: invalid_request
at Request._callback (/Users/flavio/Code/BA/node_modules/google-auth-library/lib/transporters.js:81:15)
at Request.self.callback (/Users/flavio/Code/BA/node_modules/request/request.js:188:22)
at emitTwo (events.js:106:13)
at Request.emit (events.js:191:7)
at Request.<anonymous> (/Users/flavio/Code/BA/node_modules/request/request.js:1171:10)
at emitOne (events.js:96:13)
at Request.emit (events.js:188:7)
at IncomingMessage.<anonymous> (/Users/flavio/Code/BA/node_modules/request/request.js:1091:12)
at IncomingMessage.g (events.js:286:16)
at emitNone (events.js:91:20)
at IncomingMessage.emit (events.js:185:7)
at endReadableNT (_stream_readable.js:926:12)
at _combinedTickCallback (internal/process/next_tick.js:74:11)
at process._tickCallback (internal/process/next_tick.js:98:9) code: 400 }
收到第一个错误时还可能出现什么问题?访问令牌有可能这么快就过期吗?如果是这样,我该如何正确刷新?
非常感谢任何帮助!
问题似乎是我没有正确实例化
OAuth2
。我在创建时没有将应用程序的凭据传递给构造函数。现在一切似乎都正常了。
let oauth2Client = new OAuth2(
clientID,
clientSecret,
callbackURL
);
我仍然感到唯一的困惑是为什么它在开始抛出上述错误之前对几个请求有效。
我也遇到了同样的错误,所以当我检查初始化 OAuth2Client 对象时存在问题。我正在使用 process.env,并且我提供的 client_ID 拼写错误,与我在 .env 中使用的 client_ID 拼写错误。因此,请确保您提供以下正确的详细信息