我在Google App Engine上托管了一个Python Facebook项目,并使用以下代码处理使用PyFacebook初始化Facebook API。
# Facebook Initialization
def initialize_facebook(f):
# Redirection handler
def redirect(self, url):
logger.info('Redirecting the user to: ' + url)
self.response.headers.add_header("Cache-Control", "max-age=0")
self.response.headers.add_header("Pragma", "no-cache")
self.response.out.write('<html><head><script>parent.location.replace(\'' + url + '\');</script></head></html>')
return 'Moved temporarily'
auth_token = request.params.get('auth_token', None)
fbapi = Facebook(settings['FACEBOOK_API_KEY'], settings['FACEBOOK_SECRET_KEY'], auth_token=auth_token)
if not fbapi:
logger.error('Facebook failed to initialize')
if fbapi.check_session(request) or auth_token:
pass
else:
logger.info('User not logged into Facebook')
return lambda a: redirect(a, fbapi.get_login_url())
if fbapi.added:
pass
else:
logger.info('User does not have ' + settings['FACEBOOK_APP_NAME'] + ' added')
return lambda a: redirect(a, fbapi.get_add_url())
# Return the validated API
logger.info('Facebook successfully initialized')
return lambda a: f(a, fbapi=fbapi)
我正在尝试设置它,以便我可以在任何页面处理程序方法上删除此装饰器,并验证用户是否已正确设置所有内容。问题是当调用重定向处理程序时,它会启动一个无限循环的重定向。
我尝试使用HTTP 302重定向代替JavaScript,但也一直在失败。有谁知道我能做些什么来解决这个问题?
我看到了similar question,但没有答案。
答案 0 :(得分:2)
我今天刚刚发生了同样的事情!我认为发生的是fbapi.check_session()没有正确设置fbapi.added。我不认为Post-Add URL包含'已安装',但仍然有'fb_sig_added'。 pyfacebook中的以下更改(github-esque代码)为我停止了无限重定向:
1244 | 1244 | if request.method == 'POST': 1245 | 1245 | params = self.validate_signature(request.POST) 1246 | 1246 | else: 1247 | | - if 'installed' in request.GET: | 1247 | + if 'installed' in request.GET or request.GET['fb_sig_added'] == '1': 1248 | 1248 | self.added = True
答案 1 :(得分:0)
问题似乎很熟悉。 你可以在这里使用我问题的解决方案:
app-engine-patch and pyFacebook not working
但那是与pyfacebook一起提供的装饰器,所以可能会有所不同。