मैं एक फोनगैप एप्लिकेशन बना रहा हूं जिसमें सर्वर की तरफ नोडज होगा। मैं पासपोर्ट-फेसबुक रणनीति का उपयोग करके लॉगिन लागू करना चाहता था लेकिन उनके कॉलबैक दो मार्ग,/success सफलतापूर्वक और/विफलता को निर्दिष्ट करते हैं। एक पृष्ठ एप्लिकेशन होने के कारण, यह उपयोगकर्ताओं को इतनी और इतनी पेज पर रीडायरेक्ट करने में बहुत भ्रमित कर देता है।रीडायरेक्शन के बिना पासपोर्ट-फेसबुक लॉगिन का उपयोग कैसे करें?
मैं सर्वर से स्थिर फ़ाइलों (index.html, login.html) की सेवा नहीं करना चाहता हूं बल्कि उन्हें क्लाइंट पर रखना चाहता हूं और क्लाइंट से AJAX कॉल करने के लिए कहता हूं। अब तक, मैं AJAX अनुरोध के रूप में/auth/facebook कॉल करने में सक्षम हूं लेकिन मुझे उसी अनुरोध पर कोई प्रतिक्रिया नहीं मिल सकती है क्योंकि लॉगिन रणनीति को उपयोगकर्ता को पुनर्निर्देशित करने की आवश्यकता होती है। मैं सफल लॉगिन पर उपयोगकर्ता को उपयोगकर्ता_आईडी या नाम वापस भेजना चाहता हूं या विफलता पर उसे लॉगिन फॉर्म (जो फोनगैप में www निर्देशिका पर भी है) दिखाएं। लेकिन पुनर्निर्देशन और सीओआरएस त्रुटियां मुझे ऐसा करने से रोक रही हैं। क्या मैं इसे लागू कर सकता हूं? मैंने कुछ हफ्तों के बाद से इसकी तलाश की है, लेकिन कोई सफलता नहीं है। मैं वास्तव में आपकी मदद की सराहना करता हूं!
पीएस: मैं नोड सर्वर से सभी एचटीएमएल और स्थैतिक सामग्री भेजने से बचाना चाहता हूं।
संपादित करें: बेहतर समझ के लिए लॉगिन कोड जोड़ना:
app.get('/userpage', utility.isLoggedIn, function(req, res)
{
res.send('User:'+req.user);
});
app.get('/', utility.isLoggedIn, function(req, res)
{
res.redirect('/userpage');
});
app.get('/auth/facebook', passport.authenticate('facebook'));
app.get('/auth/facebook/callback',passport.authenticate('facebook',
{
successRedirect : '/',
failureRedirect : '/login'
}));
app.get('/logout', function(req, res)
{
req.logout();
res.redirect('/login');
});
utility.isLoggedIn:
function isLoggedIn(req, res, next)
{
if (req.isAuthenticated())
return next();
res.redirect('/login');
}
इस समस्या को हल किया? मैं एक समान दृष्टिकोण में रूचि रखता हूं ... –
कोई उपयोगकर्ता आपके फेसबुक ऐप को AJAX अनुरोध के माध्यम से अनुमतियों की अनुमति कैसे देगा? क्या होगा यदि उपयोगकर्ता पहले से ही फेसबुक में लॉग इन नहीं किया गया था, तो वे AJAX अनुरोध के माध्यम से कैसे लॉग इन करेंगे? पाठ्यक्रम के इन सवालों का जवाब यह है: वे नहीं कर सके। और यही कारण है कि आप AJAX का उपयोग कर किसी भी OAuth प्रदाता के माध्यम से किसी उपयोगकर्ता को प्रमाणीकृत करने में सक्षम नहीं होंगे। – idbehold