Вопрос

Я пытаюсь установить задачу Cron для чтения обновлений для приложения Facebook. Я побудил пользователя предоставить разрешения на доступ к автономному доступу, и я сохранил Session_key в DB.

Я свечу новый объект Facebook, и, помимо API и секретного ключа, я также использую Session_key (ранее хранящий в дБ) и FB UID. Когда я пытаюсь создать токен Auth или сделать звонок API, я получу ошибку 104: Неправильная подпись

Есть идеи, опыт, подсказки?

Это было полезно?

Решение

Я только что написал запись в блоге О поиске чего -то подобного - нужно написать сценарий Python Cron. Вот что я придумал:

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

Другие советы

Я столкнулся с той же проблемой, когда отображаемая ошибка была:

"facebook.facebookerr: ошибка 104: Неправильная подпись"

Просто сбросьте свою App Secret_key и внесите соответствующие изменения в коде и что решите проблему.

Ваше здоровье!

Я никогда не использовал pyfacebook. Или пытался возобновить сеансы таким образом. Но я представляю, просто хранение session_key а также uid недостаточно. Есть и другие параметры, и парамец подписи, который рассчитывается на основе всех fb_* параметры Таким образом, вам может потребоваться хранить их все.

Но даже в этом случае они могут работать всего в течение 20-30 минут, если вам не повезло.

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top