的步骤如下:
npm init
npm install express passport passport-google-oauth2 mysql
app.js
的文件,并引入所需的模块:const express = require('express');
const passport = require('passport');
const GoogleStrategy = require('passport-google-oauth2').Strategy;
const mysql = require('mysql');
const connection = mysql.createConnection({
host: 'localhost',
user: 'your_username',
password: 'your_password',
database: 'your_database'
});
connection.connect((err) => {
if (err) {
console.error('Error connecting to MySQL database: ' + err.stack);
return;
}
console.log('Connected to MySQL database as id ' + connection.threadId);
});
passport.use(new GoogleStrategy({
clientID: 'your_client_id',
clientSecret: 'your_client_secret',
callbackURL: 'http://localhost:3000/auth/google/callback'
}, (accessToken, refreshToken, profile, done) => {
// 在这里可以处理用户认证成功后的逻辑
// 将用户信息保存到MySQL数据库中
const user = {
googleId: profile.id,
displayName: profile.displayName,
email: profile.email
};
connection.query('INSERT INTO users SET ?', user, (err, result) => {
if (err) {
console.error('Error saving user to MySQL database: ' + err.stack);
return done(err);
}
return done(null, user);
});
}));
const app = express();
app.use(passport.initialize());
app.use(passport.session());
app.get('/auth/google', passport.authenticate('google', { scope: ['profile', 'email'] }));
app.get('/auth/google/callback', passport.authenticate('google', {
successRedirect: '/profile',
failureRedirect: '/login'
}));
app.get('/profile', (req, res) => {
res.send('Welcome, ' + req.user.displayName);
});
app.get('/login', (req, res) => {
res.send('Login failed');
});
app.listen(3000, () => {
console.log('Server started on port 3000');
});
node app.js
现在,当用户通过Google认证成功后,其信息将保存到MySQL数据库中。可以根据需要进一步扩展应用程序,例如添加用户认证、授权等功能。
推荐的腾讯云相关产品:腾讯云数据库MySQL、腾讯云云服务器CVM。
腾讯云数据库MySQL产品介绍链接地址:https://cloud.tencent.com/product/cdb
腾讯云云服务器CVM产品介绍链接地址:https://cloud.tencent.com/product/cvm
企业创新在线学堂
云+社区技术沙龙[第17期]
云+社区沙龙online [国产数据库]
云原生正发声
DB-TALK 技术分享会
DB TALK 技术分享会
Techo Day
T-Day
领取专属 10元无门槛券
手把手带您无忧上云