要实现AWS Cognito用户池的LinkedIn社交登录,您可以按照以下步骤进行操作:
1.在AWS控制台中创建AWS Cognito用户池,并启用社交登录选项。确保已设置正确的回调URL和应用程序ID。
2.安装AWS SDK for JavaScript,以及LinkedIn的OAuth库,例如passport-linkedin-oauth2。
3.创建一个Express.js应用程序,并使用Passport.js进行身份验证。
4.配置Passport.js以使用LinkedIn策略,并在成功验证后将用户信息存储到Cognito用户池中。
下面是一个基本的代码示例:
// 引入所需模块
const express = require('express');
const passport = require('passport');
const LinkedInStrategy = require('passport-linkedin-oauth2').Strategy;
const AmazonCognitoIdentity = require('amazon-cognito-identity-js');
// 配置Passport.js
passport.use(new LinkedInStrategy({
clientID: 'YOUR_LINKEDIN_CLIENT_ID',
clientSecret: 'YOUR_LINKEDIN_CLIENT_SECRET',
callbackURL: 'YOUR_CALLBACK_URL',
scope: ['r_emailaddress', 'r_liteprofile'],
}, (accessToken, refreshToken, profile, done) => {
// 在这里处理LinkedIn返回的用户信息
// 将用户信息存储到Cognito用户池中
const poolData = {
UserPoolId: 'YOUR_USER_POOL_ID',
ClientId: 'YOUR_CLIENT_ID',
};
const userPool = new AmazonCognitoIdentity.CognitoUserPool(poolData);
const email = profile.emails[0].value;
const username = profile.displayName;
const attributeList = [
new AmazonCognitoIdentity.CognitoUserAttribute({ Name: 'email', Value: email }),
];
userPool.signUp(username, 'password', attributeList, null, (err, result) => {
if (err) {
console.error(err);
return done(err);
}
const cognitoUser = result.user;
console.log('user registered:', cognitoUser.getUsername());
return done(null, profile);
});
}));
// 创建Express应用程序
const app = express();
// 初始化Passport.js
app.use(passport.initialize());
// 创建登录路由
app.get('/auth/linkedin', passport.authenticate('linkedin'));
// 创建回调路由
app.get('/auth/linkedin/callback', passport.authenticate('linkedin', {
failureRedirect: '/login',
}), (req, res) => {
// 在这里根据需求进行重定向或其他操作
res.redirect('/');
});
// 启动应用程序
app.listen(3000, () => {
console.log('App listening on port 3000');
});
请注意,上述示例中的YOUR_LINKEDIN_CLIENT_ID,YOUR_LINKEDIN_CLIENT_SECRET,YOUR_CALLBACK_URL,YOUR_USER_POOL_ID和YOUR_CLIENT_ID应替换为您自己的实际值。
此示例仅提供了一个基本的实现,并假定您已经熟悉Express.js和Passport.js。您可能还需要根据您的特定需求进行适当的修改和调整。