我正在尝试将Facebook集成到我的Flask应用程序中。Facebook SDK for JavaScript 是无缝的,非常易于使用。但是我在传递数据服务器端时遇到了问题(我真正需要的只是用户的 facebook ID)。这是我的准系统烧瓶应用程序:
from flask import Flask, render_template, session, request, redirect, url_for
app = Flask(__name__)
app.config['SECRET_KEY'] = '123'
@app.route('/')
def index():
print('cookies', request.cookies)
return render_template('get_fb_cookies.html')
@app.route('/set_key')
def set_key():
session['key'] = 'value'
return redirect(url_for('index'))
if __name__ == '__main__':
app.run(debug=True)
这是我的准系统模板,它允许用户在客户端登录/注销(并利用 facebook API 的其他各种部分):
<!doctype html>
<html lang="en">
<body>
<script>
window.fbAsyncInit = function() {
FB.init({
appId : '<app-id>',
cookies : true,
version : 'v2.10' // use graph api version 2.10
});
FB.getLoginStatus(function(response) {
statusChangeCallback(response);
});
};
// Load the SDK asynchronously
(function(d, s, id) {
var js, fjs = d.getElementsByTagName(s)[0];
if (d.getElementById(id)) return;
js = d.createElement(s); js.id = id;
js.src = "//connect.facebook.net/en_US/sdk.js"; // minified version version
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
// This is called with the results from from FB.getLoginStatus().
function statusChangeCallback(response) {
if (response.status === 'connected') {
FB.api('/me', function(response){
console.log('Successful login for: ' + response.name);
console.log('ID: ' + response.id)
});
} else {
console.log('Not connected.')
}
};
</script>
<div id="fb-root"></div>
<h1>Get Facebook Cookies</h1>
<div class="fb-login-button" data-max-rows="1" data-size="medium" data-button-type="login_with" data-show-faces="false" data-auto-logout-link="true"></div>
</body>
</html>
阅读这个SO问题,似乎我需要访问cookie服务器端,但request.cookies
只是给了我flask.session
设置的cookie。也许我需要更改Facebook设置的cookie的域。现在大约有十个.facebook.com
。我想我需要将它们设置为localhost
(或我的服务器正在运行的任何位置)。
这是否可行,或者我需要考虑一种不同的方法来访问用户的Facebook ID服务器端?
与其通过尝试更改域来污染FB的cookie,我建议在statusChangeCallback
中使用GET或POST请求对Flask应用程序