我在node.js上有一个应用程序,使用Everyauth身份验证返回表单
的令牌{ access_token: 'ya29.AHES6ZTlm9qdoFuY9sdpdmFTJISGaQ_69LnW8fszSzPjSCs',
token_secret:
{ token_type: 'Bearer',
expires_in: 3600,
id_token: 'eyJhbGciOisdUzI1NiJ9.eyJpc3MiOiJhY2NvdW50cy5nb29nbGUuY29tIiwiaWQ
iOiIxMTQ0MDU3NTM5MTg1NTk1Mzc3NzciLCJhdWQiOiI0NDcwOTkyNjgzMjAuYXBwcy5nb29nbGV1c2V
yY29udGVudC5jb20iLCJjaWQiOiI0NDcwOTkyNjgzMjAuYXBwcy5nb29nbGV1c2VyY29udGVudC5jb20
iLCJ0b2tlbl9oYXNoIjoicEFXMDBIaUdaSWNRaWMtM09TLU9vQSIsImlhdCI6MTM0NjMyMzQwMiwiZXh
wIjoxMzQ2MzI3MzAyfQ.HUAhg2hdBUB2n1oUFW_9MOxAyr2O7u8GFkShxggTL2o2tBpwIi0_jLIuD1ri
mGkZwdlR5DwjODe4w2w2rLzPpb3YPCeh19zWg7pxP0huqvuVl3cPLXOkWxke46WIH9KNSQbV3oX34GA4
jTvzEV2-HCR_-GhDeG245FTSpxYpTnE',
refresh_token: '1/Ns-89zzHPbIJlFYXAOCn4dKqxklN4Wc0Og-Gga5XSJA' } }
此时如何制作“authorized request”(获取文件列表)?
我尝试过以这种形式使用node-auth:
googleOAuth = new OAuth("https://accounts.google.com/o/oauth2/auth",
"https://accounts.google.com/o/oauth2/token",
config.clientID, config.secret,
"1.0A", undefined, "HMAC-SHA1");
googleOAuth.get('https://www.googleapis.com/drive/v2/files/list', token.access_token, token.token_secret.id_token, function (error, data) {
if(error){
console.log(error)
}else{
console.log(data)
}
});
点击谷歌提示后点击“允许访问”后,googleOAuth.get会记录错误
{"error":{"statusCode":401,"data":"{\n \"error\": {\n \"errors\": [\n {\n \"domain\": \"global\",\n \"reason\": \"authError\",\n \"message\": \"Invalid Credentials\",\n \"locationType\": \"header\",\n \"location\": \"Authorization\"\n }\n ],\n \"code\": 401,\n \"message\": \"Invalid Credentials\"\n }\n}\n"}}
我应该通过get
请求传递哪种身份验证才能获得有效的文件列表?
使用两个身份验证库似乎很奇怪。不过,我不确定如何与Everyauth签署一份签名请求。它似乎只是'登录'服务而已。
答案 0 :(得分:0)
1)在我的everyauth注册用户功能中,我更新了范围以包含谷歌驱动器。
exports.register = function register (everyauth, conf, users) {
everyauth['google']
.appId(conf.google.clientID)
.appSecret(conf.google.secret)
.scope('https://www.googleapis.com/auth/drive https://www.googleapis.com/auth/userinfo.profile') // ADDED ADDITIONAL SCOPE VALUE HERE
.findOrCreateUser(function (sess, token, accessTokenExtra, googleUserData) {
var user = users.find('google', token);
if (user) {
return user;
} else {
return users.add('google', sess.id, token, accessTokenExtra, googleUserData);
}
})
.redirectPath('/');
};
2)在我的请求中,我放弃了node-oauth并使用了request,并将访问令牌作为参数。
// was googleOAuth.get('http.... etc
request('https://www.googleapis.com/drive/v2/files?access_token= + token.access_token, function (error, response, body) {
if(error){
callback(error, null);
}else{
callback(null, data);
}
});
3)此时我现在收到403错误,而不是401错误。
缺少的操作是根据此问题的答案https://stackoverflow.com/a/10370391/1408316
在我的控制台中设置Google Drive API以及Google Drive SDK