質問

Facebookアプリケーションの更新を読むためにCronタスクを設定しようとしています。ユーザーにオフラインアクセス許可を付与するように促し、session_keyをDBに保存しました。

私は新しいFacebookオブジェクトをクレアしており、APIとSecretキー以外にも、Session_Key(以前はDBに保存されていた)とFB UIDも使用しています。 Authトークンを作成しようとしている場合、またはAPI呼び出しを実行しようとしている場合、エラー104:secorrect Signatureが表示されます

アイデア、経験、ヒントはありますか?

役に立ちましたか?

解決

私はちょうど書いた ブログエントリー 似たようなものの検索について - 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.FaceBookError:エラー104:署名が正しくない」

アプリSecret_Keyをリセットして、コードに対応する変更を行うだけで問題が解決する必要があります。

乾杯!

Pyfacebookを使用したことがありません。または、この方法でセッションを再開しようとしました。しかし、私はただ保管することを想像します session_keyuid 十分ではありません。他にもパラメージがあり、すべてに基づいて計算される署名パラメーションがあります fb_* パラメーション。したがって、それらすべてを保存する必要があるかもしれません。

しかし、それでも、あなたが不運であれば、彼らは20〜30分しか働かないかもしれません。

ライセンス: CC-BY-SA帰属
所属していません StackOverflow
scroll top