Pregunta

Estoy tratando de establecer una tarea cron para leer actualizaciones para una aplicación de Facebook. He solicitado al usuario que otorgue permisos de acceso fuera de línea y he almacenado el session_key en el DB.

Estoy curtando un nuevo objeto de Facebook y, además de API y clave secreta, también uso el session_key (previamente almacenado en db) y el fb uid. Cuando intento crear el token de autenticación o hacer una llamada API, recibo un error 104: firma incorrecta

¿Alguna idea, experiencia, sugerencias?

¿Fue útil?

Solución

Acabo de escribir un Entrada de blog Sobre mi búsqueda de algo similar: necesito escribir un guión Python Cron. Esto es lo que se me ocurrió:

#!/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())

Otros consejos

Me enfrenté al mismo problema donde se muestra el error:

"Facebook.FacebookError: Error 104: firma incorrecta"

Simplemente reinicie su aplicación Secret_Key y haga el cambio correspondiente en el código y eso debe solucionar el problema.

¡Salud!

Nunca he usado pyfacebook. O traté de reanudar las sesiones de esta manera. Pero me imagino solo almacenar session_key y uid no es suficiente. También hay otros parámetros y un parámetro de firma que se calcula en base a todos los fb_* parámetros. Por lo tanto, es posible que necesite almacenarlos todos.

Pero aun así, solo podrían funcionar durante 20-30 minutos si tienes mala suerte.

Licenciado bajo: CC-BY-SA con atribución
No afiliado a StackOverflow
scroll top