Как перенаправить URL-адрес после входа в Facebook?

Я создал приложение django с подключением Facebook к приложению. Теперь, когда я нажимаю кнопку входа в Facebook, всплывает страница oauth. Когда я даю имя пользователя и пароль, он закрывается без фактического перенаправления страницы на любую страницу. Но когда я перешел на страницу FB на новой вкладке, я мог видеть страницу входа в FB этого пользователя. Таким образом, вход в систему работает отлично, но я не понимаю, где указать перенаправление страницы после ее аутентификации. Может ли кто-нибудь помочь мне решить эту проблему. Это как я установил на своей странице настроек? Я не смог найти URL-адрес обратного вызова, который можно было бы установить в параметрах.

App ID
xxxx
API Key
xxxx
App Secret
xxx
Site URL
http://localhost:8080/redirect_url/
Site Domain
localhost
Canvas Page
http://apps.facebook.com/registrationforms/
Canvas URL
http://apps.facebook.com/registrationforms/
Secure Canvas URL
Canvas FBML/iframe
iframe

Код для входа: этот фрагмент кода вставляется в html-страницу RegistrationForm (логин):

{% load facebookconnect %}
{% facebook_connect_login_button %}
{% facebook_connect_script %}

и код facebookconnect.py:

from django import template
from django.conf import settings
from django.core.urlresolvers import reverse

register = template.Library()

class FacebookScriptNode(template.Node):
        def render(self, context):
            return """
            <script src="http://static.ak.connect.facebook.com/js/api_lib/v0.4/FeatureLoader.js.php" type="text/javascript"></script>


            <script type="text/javascript"> FB.init("%s", "%s");
                function facebook_onlogin() {
                    var uid = FB.Facebook.apiClient.get_session().uid;
                    var session_key = FB.Facebook.apiClient.get_session().session_key;
                    var expires = FB.Facebook.apiClient.get_session().expires;
                    var secret = FB.Facebook.apiClient.get_session().secret;
                    var sig = FB.Facebook.apiClient.get_session().sig;

                    fb_connect_ajax(expires, session_key, secret, uid, sig);

                }

                function fb_connect_ajax(expires, session_key, ss, user, sig) {

                    var post_string = 'expires=' + expires;
                    post_string = post_string + '&session_key=' + session_key;
                    post_string = post_string + '&ss=' + ss;
                    post_string = post_string + '&user=' + user;
                    post_string = post_string + '&sig=' + sig;

                    $.ajax({
                        type: "POST",
                        url: "%s",
                        data: post_string,
                        success: function(msg) {
                            window.location = '%s'; //.reload()
                        }
                    });
                } 
            </script>       
            """ % (settings.FACEBOOK_API_KEY, reverse('xd_receiver'), reverse('facebook_connect_ajax'), settings.LOGIN_REDIRECT_URL)


def facebook_connect_script(parser, token): return FacebookScriptNode()

register.tag(facebook_connect_script)

class FacebookLoginNode(template.Node):
    def render(self, context): 
        return "<fb:login-button onlogin='facebook_onlogin();'></fb:login-button>"
        #return "<fb:login-button onclick="openPopup('https://graph.facebook.com/oauth/authorize?client_id=a0acfd122e64fc21cfa34d47369f0c97&redirect_uri=http://mysite.com/mypage&display=popup');"></fb:login-button>"



def facebook_connect_login_button(parser, token): return FacebookLoginNode()

register.tag(facebook_connect_login_button)

person rv_k    schedule 20.04.2011    source источник
comment
опубликуйте свой код для всплывающего окна входа.   -  person Love Sharma    schedule 20.04.2011
comment
Я разместил свой код входа в FB. Не могли бы вы проверить сейчас?   -  person rv_k    schedule 21.04.2011


Ответы (2)


Я предполагаю, что вы используете библиотеку JS Facebook, если вы говорите, что oauth просто всплывает. Я бы пошел по более простому пути перенаправления oauth, используя следующее:

def build_authentication_redirect(self):
            args = {}
            args["client_id"]=self.app_id
            args["redirect_uri"]=self.redirect_uri
            args["scope"]=",".join(self.req_perms)
            redirect_url = "https://www.facebook.com/dialog/oauth?"+urllib.urlencode(args)
            redirect_code = """
                    <script type="text/javascript">
                    top.location.href='%s';
                    </script>
            """ % redirect_url;
            return HttpResponse(redirect_code,mimetype="text/html")

Где self.app_id — идентификатор вашего приложения в Facebook. Где self.redirect_uri — это URL-адрес, на который пользователь будет перенаправлен после входа в систему. Где self.scope построен из self.req_perms, который представляет собой массив необходимых разрешений.

После этого пользователь будет перенаправлен на redirect_uri с токеном доступа в параметре сообщения «signed_request», вы можете использовать следующую функцию для его декодирования:

def load_signed_request(self, signed_request):
            """Load the user state from a signed_request value"""
            sig, payload = signed_request.split(u'.', 1)
            sig = self.base64_url_decode(sig)
            data = json.loads(self.base64_url_decode(payload))

            expected_sig = hmac.new(self.app_secret, msg=payload, digestmod=hashlib.sha256).digest()

            # allow the signed_request to function for upto 1 day
            if sig == expected_sig and data[u'issued_at'] > (time.time() - 86400):
                    return data.get(u'user_id'), data.get(u'oauth_token')
            else:
                    return None,None

Пример :

sigreq =request.POST.get('signed_request', None)
user_id,access_token = load_signed_request(sigreq)

Вам снова понадобится self.app_secret и следующая функция:

@staticmethod
    def base64_url_decode(data):
            data = data.encode(u'ascii')
            data += '=' * (4 - (len(data) % 4))
            return base64.urlsafe_b64decode(data)

У меня было много проблем с входом и аутентификацией FB JS, особенно в разных браузерах, это более надежный способ, который я смог найти :)

Кстати, если вам нужен мой файл facebook.py, я могу разместить его где-нибудь в Интернете... У него даже есть декораторы вида @fbsig_required и @fbsig_redirect...

О Также вот мой импорт:

import cgi
import hashlib
import time
import urllib
import base64
import datetime
import hmac

from django.conf import settings
from django.http import HttpResponseRedirect,HttpResponse,HttpResponseNotFound
person dwarfy    schedule 20.04.2011
comment
Большое спасибо за вашу помощь, dwarfy.. я проверю это и отвечу.. Можете ли вы также поделиться своим файлом facebook.py для меня? - person rv_k; 21.04.2011
comment
Вы можете найти мой файл facebook.py здесь, на битбакете - person dwarfy; 21.04.2011

Проверьте это, может это даст вам некоторое представление о том, как сделать эту работу:

https://stackoverflow.com/questions/2690723/facebook-graph-api-and-django/5539531#5539531

person Love Sharma    schedule 21.04.2011