404错误尝试使用Facebook测试用户login_url

时间:2014-03-22 21:42:25

标签: facebook facebook-graph-api facebook-test-users

如果我以编程方式创建Facebook test user,则新用户的login_url无效。获取login_url会返回404错误。

简化示例(在Python中)。最后两行是问题出现的地方:

import requests
from urlparse import parse_qs
APP_ID = "<Facebook App ID>"
APP_SECRET = "<Facebook Client Secret>"

# Get app access token - this works
response = requests.get('https://graph.facebook.com/oauth/access_token',
                        params={'grant_type': "client_credentials",
                                'client_id': APP_ID, 'client_secret': APP_SECRET})
app_access_token = parse_qs(response.content)['access_token'][0]

# Create test user - this works
response = requests.post('https://graph.facebook.com/%s/accounts/test-users' % APP_ID,
                         data={'access_token': app_access_token, 'installed': "true"})
test_user = response.json()
login_url = test_user['login_url']
print login_url  # http://developers.facebook.com/checkpoint/test-user-login/...

# Get cookied for login - see https://stackoverflow.com/a/5370869/647002
session = requests.Session()
session.get("https://www.facebook.com/", allow_redirects=True)

# Login test user - THIS FAILS
response = session.get(login_url)
print response.status_code  # 404
在测试用户的login_url之前,您必须Others have noted

first fetch the Facebook homepage才能正常工作。我们遇到了同样的问题,我已经将上述解决方法包括在内,没有任何运气。 [编辑:添加了_fb_noscript=1查询参数,从2015年中开始为非JavaScript测试客户端添加。[编辑8/2017:现已删除_fb_noscript=1;不再需要,并设置noscript cookie,使稍后的FB身份验证请求返回500.]

我也试过直接在浏览器中打开login_url:

  • 如果我 已经登录Facebook,我会获得一个通用的Facebook 404页面。
  • 如果我已登录我的开发者帐户,Facebook会警告我将以平台测试用户身份登录,然后允许我进入测试用户的帐户。

最后一点似乎确认正在正确创建测试用户并且我有正确的login_url。但是,当然,这对自动化测试毫无帮助。 (我们不想运行登录到我的开发者帐户的测试。)

测试用户的login_url是否还有其他方式可用于自动化测试?

1 个答案:

答案 0 :(得分:6)

Facebook开发人员支持工程师has confirmed,由于安全性的变化,测试用户login_url无法再用于测试用户的自动登录。显然它意味着手动测试。

然而, 能够通过发布到Facebook的正常登录表单来实现以编程方式创建的Facebook测试用户的自动登录。您似乎只需要从create-test-user API返回的电子邮件和密码。 (似乎不需要其他登录表单字段,但您仍然需要先获取cookie。)

下面的代码现在正在为我工​​作(替换最后两个&#34;这失败&#34;来自原始问题的代码行):

# Login test user - THIS WORKS
response = session.post("https://www.facebook.com/login.php",
                        data={'email': test_user["email"],
                              'pass': test_user["password"]})
print response.status_code  # 200

我还没有在任何地方找到这个文件,Facebook可能会在将来更改他们的登录表单,所以YMMV。