Пока у меня есть приложение, которое перенаправляет на страницу согласия. Пользователь принимает, затем я перенаправлен обратно на локальный хост с действительным кодом авторизации. Из того, что я понимаю, мне нужно сделать еще один звонок и обменять этот код на токен доступа. getAccessToken()
не работает, однако. Журнал консоли возвращает это:
invalid_client
invalid_request
Пожалуйста, дайте мне знать, какая дополнительная информация необходима.
Вот соответствующий код:
var { google } = require('googleapis');
var http = require("http");
var request = require('request');
var oauth2Client = new google.auth.OAuth2(
'<My Client ID>',
'<My Client Secret>',
'http://localhost:8080'
);
exports.generateAuthCodeUrl = function () {
const url = oauth2Client.generateAuthUrl({
access_type: 'offline',
scope: 'https://www.googleapis.com/auth/blogger'
});
return url;
};
exports.getAccessToken = function (accessCode) {
var codeOptions = {
code: accessCode
}
oauth2Client.getToken(codeOptions, function (err, tokens) {
// Now tokens contains an access_token and an optional refresh_token. Save them.
if (!err) {
oauth2Client.setCredentials(tokens);
return tokens;
}
console.log(err.message);
});
};
Редактировать: Резюме и что сработало для меня
Я прочитал связанную статью из ответа Пиноиида ДВАЖДЫ, а также отметил шаги, перечисленные в его ответе. Перечисление простых шагов помогло мне понять более ясно. Кроме того, как рекомендовано в комментариях, я удалил библиотеку googleapi ( Ошибка, упомянутая выше, возникала в коде этой библиотеки ), и просто регулярно вызывал нужные конечные точки с помощью request
библиотека. Я использовал request
, потому что это намного менее многословно. Код, с которым я столкнулся, выглядит следующим образом:
exports.generateAuthCodeUrl = function () {
var authURL = "https://accounts.google.com/o/oauth2/v2/auth?" +
"client_id=" + client_id +
"&scope=" + scope +
"&redirect_uri=" + redirect_uri +
"&response_type=" + response_type;
//redirect to consent page
return authURL;
};
exports.getAccessToken = function (x) {
var postDataUrl = 'https://www.googleapis.com/oauth2/v4/token?' +
'code=' + x + //auth code received from the previous call
'&client_id=' + client_id +
'&client_secret=' + client_secret +
'&redirect_uri=' + redirect_uri +
'&grant_type=' + "authorization_code"
var options = {
uri: postDataUrl,
method: 'POST'
};
request(options, function (err, res, body) {
return body; //returns an object with an access token!!!
});
};
Очень рад, что у меня это работает !! Спасибо всем большое