OAuth2和Node.js - Google确认后无重定向
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了OAuth2和Node.js - Google确认后无重定向相关的知识,希望对你有一定的参考价值。
我正在使用Node.js通过Google+验证我的网络应用程序。我按照官方指示here。我的代码看起来像这样:
var google = require('googleapis');
// OAuth
var OAuth2 = google.auth.OAuth2;
var plus = google.plus('v1');
var oauth2Client = new OAuth2(
'MY_CLIENT_ID', // Client id
'MY_CLIENT_SECRET', // Client secret
'http://localhost:8080/oauth' // Redirect url
);
function getOAuthUrl(){
var url = oauth2Client.generateAuthUrl({
access_type: 'offline',
scope: 'https://www.googleapis.com/auth/plus.me'
});
return url;
}
// OAuth authorization
app.use('/oauth', function(req, res){
var session = req.session;
var code = req.query.code;
oauth2Client.getToken(code, function(err, tokens) {
// Now tokens contains an access_token and an optional refresh_token. Save them.
if (!err) {
oauth2Client.setCredentials(tokens);
session['tokens'] = tokens;
res.redirect(__dirname + '/public/html/redirect.html?r=1'); // Success!
}else{
res.redirect(__dirname + '/public/html/redirect.html?r=0'); // Fail!
}
});
});
登录页面在我的文件夹的根目录中被称为index.html
。登录页面向/oauth/url
发出ajax请求,该请求以用户必须单击的OAuth2网址进行响应。
关于index.html
的JS:
/* OAuth */
$.ajax({
url: '/oauth/url',
dataType: 'text',
cache: false,
success: function (e) {
$('#login').attr('href', e);
}
});
Node.js响应:
// Get OAuth URL
app.use('/oauth/url', function(req, res){
var url = getOAuthUrl();
res.end(url);
});
我可以点击链接将我带到正常的身份验证页面。但是,当我选择要进行身份验证的帐户时,该页面会冻结,并且不会像它应该的那样重定向到localhost:8080/oauth
。
更新:查看控制台上的网络选项卡,我注意到正在取消对回调的GET
请求。代码由Node.js接收,请求也是如此。
答案
解决了:
问题在于静态目录不允许Node.js重定向页面。通过将重定向地址更改为/html/redirect.html
来修复。谢谢你@James。
以上是关于OAuth2和Node.js - Google确认后无重定向的主要内容,如果未能解决你的问题,请参考以下文章
在 Google Contacts API 3.0 版上使用 oauth2 检索刷新令牌
使用 RESTify Node.js 创建 OAuth2.0 服务提供者
有人使用带有 OAuth2.0 身份验证系统的 node.js 吗? [关闭]