auth.js
2.48 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
var express = require('express');
var router = express.Router();
var UserModel = require('../models/UserModel');
var passport = require('passport');
var FacebookStrategy = require('passport-facebook').Strategy;
passport.serializeUser(function (user, done) {
done(null, user);
});
passport.deserializeUser(function (user, done) {
done(null, user);
});
passport.use(new FacebookStrategy({
// https://developers.facebook.com에서 appId 및 scretID 발급
clientID: "863352300499259", //입력하세요
clientSecret: "36867723fbdd49dac987f9a061e2206a", //입력하세요.
callbackURL: "http://localhost:3000/auth/facebook/callback",
profileFields: ['id', 'displayName', 'photos', 'email'] //받고 싶은 필드 나열
},
function(accessToken, refreshToken, profile, done) {
//아래 하나씩 찍어보면서 데이터를 참고해주세요.
//console.log(profile);
//console.log(profile.displayName);
//console.log(profile.emails[0].value);
//console.log(profile._raw);
//console.log(profile._json);
UserModel.findOne({ username : "fb_" + profile.id }, function(err, user){
if(!user){ //없으면 회원가입 후 로그인 성공페이지 이동
var regData = { //DB에 등록 및 세션에 등록될 데이터
username : "fb_" + profile.id,
password : "facebook_login",
displayname : profile.displayName
};
var User = new UserModel(regData);
User.save(function(err){ //DB저장
done(null,regData); //세션 등록
});
}else{ //있으면 DB에서 가져와서 세션등록
done(null,user);
}
});
}
));
// http://localhost:3000/auth/facebook 접근시 facebook으로 넘길 url 작성해줌
router.get('/facebook', passport.authenticate('facebook', { scope: 'email'}) );
//인증후 페이스북에서 이 주소로 리턴해줌. 상단에 적은 callbackURL과 일치
router.get('/facebook/callback',
passport.authenticate('facebook',
{
successRedirect: '/',
failureRedirect: '/auth/facebook/fail'
}
)
);
//로그인 성공시 이동할 주소
router.get('/facebook/success', function(req,res){
res.send(req.user);
});
router.get('/facebook/fail', function(req,res){
res.send('facebook login fail');
});
module.exports = router;