Pergunta

Estou tentando definir uma tarefa CRON para ler atualizações para um aplicativo no Facebook. Eu levei o usuário a conceder permissões de acesso offline e guardo o session_key no banco de dados.

Estou cambaleando um novo objeto do Facebook e, além da API e Secret Key, também uso o session_key (anteriormente armazenado em db) e o FB UID. Quando estou tentando criar o token de autenticação ou fazer uma chamada de API, recebo um erro 104: assinatura incorreta

Alguma ideia, experiência, dicas?

Foi útil?

Solução

Acabei de escrever um entrada no blog sobre minha busca por algo semelhante - preciso escrever um script python cron. Aqui está o que eu criei:

#!/usr/bin/python
import os, sys, optparse, time, json
import facebook

##

USER_SESSION_FILE = os.path.expanduser('fb-user.session')
APP_KEY_FILE = os.path.expanduser('fb-app.keys')

##

def main():
    app_keys = open(APP_KEY_FILE).readlines()
    fb_api = facebook.Facebook(api_key=app_keys[0].strip(), secret_key=app_keys[1].strip())
    opts, args = parse_options()
    if args == ['init']:
        init(fb_api)
        return
    session = json.load(open(USER_SESSION_FILE))
    fb_api.uid = session['uid']
    fb_api.secret = session['secret']
    fb_api.session_key = session['session_key']

    fb_api.stream.publish(message="test from PyFacebook")


def init(fb_api):
    fb_api.auth.createToken()

    sys.stdout.write('Opening web page to add application (press ENTER when done)...')
    sys.stdout.flush()
    fb_api.login()
    raw_input()

    sys.stdout.write('Asking for offline access now...')
    sys.stdout.flush()
    fb_api.request_extended_permission('offline_access')
    raw_input()

    sys.stdout.write('And, finally, asking for permission to publish')
    sys.stdout.flush()
    fb_api.request_extended_permission('publish_stream')
    raw_input()

    fb_api.auth.getSession()

    if fb_api.session_key_expires != 0:
        print """We were granted a temporary key; please wait a minute and run `%s init` again.""" % (sys.argv[0],)
    else:
        if not os.path.exists(USER_SESSION_FILE):
            # Only set restrictive permissions when creating the file
            # ourselves.
            open(USER_SESSION_FILE, 'w').close()
            os.chmod(USER_SESSION_FILE, 0600)
        json.dump({
                   'uid': fb_api.uid,
                   'secret': fb_api.secret,
                   'session_key': fb_api.session_key,
                   },
                   open(USER_SESSION_FILE, 'w'),
                   sort_keys=True,
                   indent=4)


def parse_options():
    p = optparse.OptionParser()
    return p.parse_args()


if __name__ == '__main__':
    sys.exit(main())

Outras dicas

Eu enfrentei o mesmo problema em que o erro exibido foi:

"Facebook.FacebookError: Erro 104: assinatura incorreta"

Basta redefinir seu aplicativo secret_key e fazer alterações correspondentes no código e isso corrige o problema.

Felicidades!

Eu nunca usei o pyfacebook. Ou tentou retomar as sessões dessa maneira. Mas eu imagino apenas armazenar session_key e uid não é o suficiente. Também existem outros parâmetros, e um parâmetro de assinatura calculado com base em todos os fb_* params. Então você pode precisar armazenar todos eles.

Mas, mesmo assim, eles podem funcionar apenas por 20 a 30 minutos se você for azar.

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