Pergunta

Estou usando a API do Facebook Graph no Google App Engine. Consegui buscar todas as informações básicas de um usuário. No entanto, quando tentei buscar qualquer informação do usuário que requer permissão, e -mail para exemplos, sempre aparece como nenhum. Eu segui todo o tutorial disponível no Blog de desenvolvedores.

Aqui está o meu código:

class User(db.Model):
    id = db.StringProperty(required=True)
    created = db.DateTimeProperty(auto_now_add=True)
    updated = db.DateTimeProperty(auto_now=True)
    name = db.StringProperty(required=True)
    email = db.StringProperty(required=True)
    profile_url = db.StringProperty(required=True)
    access_token = db.StringProperty(required=True)


class BaseHandler(webapp.RequestHandler):
    """Provides access to the active Facebook user in self.current_user

    The property is lazy-loaded on first access, using the cookie saved
    by the Facebook JavaScript SDK to determine the user ID of the active
    user. See http://developers.facebook.com/docs/authentication/ for
    more information.
    """
    @property
    def current_user(self):
        if not hasattr(self, "_current_user"):
            self._current_user = None
            cookie = facebook.get_user_from_cookie(
                self.request.cookies, FACEBOOK_APP_ID, FACEBOOK_APP_SECRET)
            if cookie:
                # Store a local instance of the user data so we don't need
                # a round-trip to Facebook on every request
                user = User.get_by_key_name(cookie["uid"])
                if not user:
                    graph = facebook.GraphAPI(cookie["access_token"])
                    profile = graph.get_object("me")
                    user = User(key_name=str(profile["id"]),
                                id=str(profile["id"]),
                                name=profile["name"],
                                email=profile["email"],
                                profile_url=profile["link"],
                                access_token=cookie["access_token"])
                    user.put()
                elif user.access_token != cookie["access_token"]:
                    user.access_token = cookie["access_token"]
                    user.put()
                self._current_user = user
        return self._current_user

E aqui está o modelo/html:

<fb:login-button autologoutlink="true" perms="email"></fb:login-button>

{% if current_user %}
  <p><a href="{{ current_user.profile_url }}"><img src="http://graph.facebook.com/{{ current_user.id }}/picture?type=square"/></a></p>
  <p>Hello, {{ current_user.name|escape }}</p>
  <p>email: {{ current_user.email }} </p>
{% endif %}

Há algo de errado? Existe outra maneira de receber o email do usuário?

Foi útil?

Solução 2

Acabei de desistir de usar Facebook.py e facebookoauth.py e fiz meu próprio cliente OAuth 2 usando o URLFETCH. Ver 'Usuários autenticando em um aplicativo da web' nos documentos do Facebook.

Além disso, eu coloco scope='email' em solicitações para https://graph.facebook.com/oauth/authorize? e https://graph.facebook.com/oauth/access_token?.

Outras dicas

O email está escrito na criação de usuários. Talvez você esteja tentando acessar usuários criados quando você não tinha permissão de email; portanto, o email escrito não foi. O problema aparece também para o novo objeto de usuário?

Seu código parece correto, então eu presumo que você não tenha as permissões estendidas corretas. Você deve solicitar a permissão estendida "email" se você tentar obter o endereço de e -mail. Você pode encontrar a lista de permissões estendidas aqui. Você deve solicitar essas permissões antes de poder ler essas propriedades usando a API do gráfico.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top