我在用MySQL设置passport-facebook时遇到了困难。
无论我往哪里看,我都能找到mongodb,使用mongodb可以将profile._json对象发送到数据库中,但使用MySQL则不能。
passport.use(new FacebookStrategy({
clientID : "",
clientSecret : "",
callbackURL : ""
}), function (accessToken, refreshToken, profile, done){
db.query("SELECT * FROM users WHERE facebook_id = ?", [profile.id], function(err, user){
if (err){
return done(err);
}
else if (user.length == 0){
var name = profile.displayName;
var email = profile.emails[0].value;
var username = profile.username;
var provider = "facebook";
var facebook = profile._json;
db.query("INSERT INTO users (name, email, username, provider, token) VALUES (?, ?, ?, ?, ?)",
[name, email, username, provider, /* profile._json?? */], function(err){
})
}
else{
return done(err, user);
}
});
});为了在MySQL数据库中创建字段,需要保存的profile._json内容及其类型是什么?
有没有可能我应该建立mongodb并将这些信息保存在那里,然后使用MySQL数据库来完成剩下的工作?我的API也使用了google身份验证。
发布于 2019-03-31 21:18:37
尝尝这个
let user= {Facebook_ID: profile.id, First_Name: profile.displayName, FB_Private_Chat_ID: '000001100'};
mysqlconnection.query('INSERT INTO users SET ?', user, (err, res) => {
if(err) throw err;
console.log('Last insert ID:', profile.id);
})https://stackoverflow.com/questions/37064804
复制相似问题