2013-03-26 135 views
4

我需要在我的自己的 Facebook页面上发布消息;我需要这样做以编程方式(在我的情况下使用Python)。我成功地做到使用此代码(在Python)这一部分:Facebook:如何以编程方式检索访问令牌?

import urllib, urllib2 

access_token='XXXX' 
fb_page_id='YYYY' # my page ID 

post_data = {'access_token':access_token, 'message':'hey this is a test!'} 
request_path = str(fb_page_id)+'/feed' 
post_data = urllib.urlencode(post_data) 
response = urllib2.urlopen(
    'https://graph.facebook.com/%s' % request_path, post_data 
) 

的FB页面上生成的帖子的ID是正确返回:

In [11]: response.readlines() 
Out[11]: ['{"id":"135386143198208_461964357207050"}'] 

问题:

为了生成access_token并提出上述API请求,我必须手动按照详细here的三个步骤。

但实际上这个手动过程是不可接受的,因为我需要从cron作业运行此任务。因此我需要自动化它,因为Facebook中的access_token是暂时的。即每次运行此脚本时,我都需要获取访问令牌。怎么做?

只要您传达涉及的步骤,就可以在答案(卷曲,JavaScript,Java,PHP)中随意使用任何脚本工具。请注意,我需要使用任何服务器端语言(Python/Ruby/PHP)来执行此操作。

+2

downvote的任何理由?谢谢;) – 2013-03-26 16:28:03

+0

您不能绕过Facebook访问令牌的手动用户身份验证。这是为了一个目的。 – phwd 2013-03-26 16:55:48

+0

@phwd而且我们必须至少每两个月手动验证一次手动“访问令牌”......我是否正确? – 2013-03-26 17:02:35

回答

4

如果扩展您的(用户)访问令牌,则可以请求一个根本不会实际到期的(Page)访问令牌。

请参见下面的文档的“扩展页面访问令牌”部分:https://developers.facebook.com/docs/howtos/login/extending-tokens/

+0

确实你是对的!谢谢!这甚至不需要以编程方式完成,因为我可以只做一次,它不会过期。正确? – 2013-03-26 23:11:46

+0

什么'APP_ID'和'APP_SECRET'应该传递给该URL? – 2013-03-27 00:00:04

+0

当您注册Facebook应用程序时,您将获得应用程序ID和密码。 (创建一个后,它会显示在页面的顶部) – 2013-03-31 02:00:21

4

不能以编程方式检索短期标记。它破坏了用户交互的目的。

Facebook故意以这种方式确保用户完全手动控制他们安装的应用程序。

一旦用户授权初始接入做一个HTTP请求到

(如果用户通过更改密码无效令牌,例如或更早版本),你可以再向上过程自动化,两个月

https://graph.facebook.com/oauth/access_token? 
    grant_type=fb_exchange_token&   
    client_id=APP_ID& 
    client_secret=APP_SECRET& 
    fb_exchange_token=SHORT_LIVED_ACCESS_TOKEN 

在这两个月结束之后,用户必须是重新授予应用程序访问权限的人员,才能获得新的短期令牌,然后您可以使用上述代码重新扩展令牌。

0

要获取甚至普通用户Facebook的令牌编程,你可能会感兴趣的:https://github.com/fbessez/Tinder/blob/master/fb_auth_token.py,这是一个Python脚本自动检索提供电子邮件/密码时的令牌。

请确保您安装了lxml,requestsrobobrowser,因为这些是先决条件。无论requestsrobobrowser可以运行

pip install robobrowser

pip install requests

的LXML是一个“小”更靠谱,因为它已经被编译很容易获得性(有一个最新版本)。按照这个SO吧:How to install lxml on Ubuntu

0

祝福写这段代码的灵魂。不是我,而是在某个地方找到了它。工作顺利。使用您的电子邮件&密码调用此函数。

MOBILE_USER_AGENT = "Mozilla/5.0 (Linux; U; en-gb; KFTHWI Build/JDQ39) AppleWebKit/535.19 (KHTML, like Gecko) Silk/3.16 Safari/535.19" 
FB_AUTH = "https://www.facebook.com/v2.6/dialog/oauth?redirect_uri=fb464891386855067%3A%2F%2Fauthorize%2F&display=touch&state=%7B%22challenge%22%3A%22IUUkEUqIGud332lfu%252BMJhxL4Wlc%253D%22%2C%220_auth_logger_id%22%3A%2230F06532-A1B9-4B10-BB28-B29956C71AB1%22%2C%22com.facebook.sdk_client_state%22%3Atrue%2C%223_method%22%3A%22sfvc_auth%22%7D&scope=user_birthday%2Cuser_photos%2Cuser_education_history%2Cemail%2Cuser_relationship_details%2Cuser_friends%2Cuser_work_history%2Cuser_likes&response_type=token%2Csigned_request&default_audience=friends&return_scopes=true&auth_type=rerequest&client_id=464891386855067&ret=login&sdk=ios&logger_id=30F06532-A1B9-4B10-BB28-B29956C71AB1&ext=1470840777&hash=AeZqkIcf-NEW6vBd" 

def get_access_token(email, password): 
    s = robobrowser.RoboBrowser(user_agent=MOBILE_USER_AGENT, parser="lxml") 
    s.open(FB_AUTH) 
    ##submit login form## 
    f = s.get_form() 
    f["pass"] = password 
    f["email"] = email 
    s.submit_form(f) 
    ##click the 'ok' button on the dialog informing you that you have already authenticated with the Tinder app## 
    f = s.get_form() 
    s.submit_form(f, submit=f.submit_fields['__CONFIRM__']) 
    ##get access token from the html response## 
    access_token = re.search(r"access_token=([\w\d]+)", s.response.content.decode()).groups()[0] 
    #print s.response.content.decode() 
    return access_token