我见过多个使用node.js和facebook connect的工具。然而,其中许多似乎不完整,过于复杂(非抽象)或不再更新/维护。
我找到了这三个项目:
https://github.com/DracoBlue/node-facebook-client
https://github.com/dominiek/node-facebook
https://github.com/egorFiNE/facebook-connect
https://github.com/ciaranj/node-oauth
其中一位作者甚至讨论了为什么他再次推出了自己的,由于其他实现中的缺点:
http://groups.google.com/group/nodejs/browse_thread/thread/bb46cb08e51fdda6
有没有人真正体验过用户身份并使用node.js和facebook connect将他们的facebook id存储在他们的数据库中?
我觉得答案几乎没有,我必须建立在上述系统之一的基础上,以使事情变得更简单,但我想先检查一下。
编辑:注意确保使用node.js的STABLE版本
答案 0 :(得分:17)
你没找到ciaranj的connect-auth
const fbId = ""; #x
const fbSecret = ""; #y
const fbCallbackAddress= "http://localhost:4000/auth/facebook";
//var RedisStore = require('connect-redis');
var express= require('express');
var auth= require('connect-auth')
var app = express.createServer();
app.configure(function(){
app.use(express.cookieDecoder());
app.use(express.logger());
//app.use(connect.session({ store: new RedisStore({ maxAge: 10080000 }) }));
app.use(express.session());
app.use(auth( [
auth.Facebook({appId : fbId, appSecret: fbSecret, scope: "email", callback: fbCallbackAddress})
]) );
});
app.get('/logout', function(req, res, params) {
req.logout();
res.writeHead(303, { 'Location': "/" });
res.end('');
});
app.get('/', function(req, res, params) {
if( !req.isAuthenticated() ) {
res.send('<html> \n\
<head> \n\
<title>connect Auth -- Not Authenticated</title> \n\
<script src="http://static.ak.fbcdn.net/connect/en_US/core.js"></script> \n\
</head><body> \n\
<div id="wrapper"> \n\
<h1>Not authenticated</h1> \n\
<div class="fb_button" id="fb-login" style="float:left; background-position: left -188px"> \n\
<a href="/auth/facebook" class="fb_button_medium"> \n\
<span id="fb_login_text" class="fb_button_text"> \n\
Connect with Facebook \n\
</span> \n\
</a> \n\
</div></body></html>');
} else {
res.send( JSON.stringify( req.getAuthDetails()) );
}
});
// Method to handle a sign-in with a specified method type, and a url to go back to ...
app.get('/auth/facebook', function(req,res) {
req.authenticate(['facebook'], function(error, authenticated) {
if(authenticated ) {
res.send("<html><h1>Hello Facebook user:" + JSON.stringify( req.getAuthDetails() ) + ".</h1></html>")
}
else {
res.send("<html><h1>Facebook authentication failed :( </h1></html>")
}
});
});
app.listen(4000);
答案 1 :(得分:8)
我觉得passport-facebook相当简单实用 我也喜欢核心护照模块有80多种身份验证策略 (例如twitter,google,foursquare,github,digg,dropbox)。
来自创作者的github自述文件:
// Set up the strategy
passport.use(new FacebookStrategy({
clientID: FACEBOOK_APP_ID,
clientSecret: FACEBOOK_APP_SECRET,
callbackURL: "http://localhost:3000/auth/facebook/callback"
},
function(accessToken, refreshToken, profile, done) {
User.findOrCreate({ facebookId: profile.id }, function (err, user) {
return done(err, user);
});
}
));
// Use the authentication
app.get('/auth/facebook',
passport.authenticate('facebook'),
function(req, res){
// The request will be redirected to Facebook for authentication, so
// this function will not be called.
});
app.get('/auth/facebook/callback',
passport.authenticate('facebook', { failureRedirect: '/login' }),
function(req, res) {
// Successful authentication, redirect home.
res.redirect('/');
});
答案 2 :(得分:1)
我使用了Brian Noguchi的Everyauth。它适用于w / node.js v.0.4.x.你可以找到here。
它使用mongoose-auth插件对mongodb进行原生支持,再次由brian编写。