سؤال

أحاول تعيين مهمة cron لقراءة التحديثات لتطبيق Facebook. لقد دفعت المستخدم إلى منح أذونات الوصول دون اتصال بالإنترنت ولقد قمت بتخزين Session_key في DB.

أقوم بتجميع كائن Facebook جديدًا ، بالإضافة إلى API والمفتاح السري ، أستخدم أيضًا Session_key (تم تخزينه مسبقًا في DB) و FB UID. عندما أحاول إنشاء رمز المصادقة أو إجراء مكالمة 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.facebookerror: خطأ 104: توقيع غير صحيح"

ما عليك سوى إعادة تعيين App Secret_key وإجراء تغيير مماثل في الكود وأن SGOULD يحل المشكلة.

هتافات!

لم أستخدم Pyfacebook أبدًا. أو حاول استئناف الجلسات بهذه الطريقة. لكنني أتخيل فقط تخزين session_key و uid ليس كافيا. هناك معاملات أخرى أيضًا ، و parm توقيع يتم حسابها على أساس كل fb_* بارامز. لذلك قد تحتاج إلى تخزين كل منهم.

لكن على الرغم من ذلك ، فقد يعملون فقط لمدة 20-30 دقيقة إذا كنت محظوظًا.

مرخصة بموجب: CC-BY-SA مع الإسناد
لا تنتمي إلى StackOverflow
scroll top