所以我完成了使用 javascript sdk 链接 facebook 登录。
<script>
window.fbAsyncInit = function() {
FB.init({
appId: '{{facebook_app_id}}',
channelUrl : '//localhost:8097/channel.html',
status: true,
cookie: true,
xfbml: true
});
FB.getLoginStatus(function(response) {
if (response.status === 'connected') {
// connected
alert(response.authResponse.userID);
FB.api('/me', function(response) {
var userInfo = document.getElementById('user-info');
userInfo.innerHTML = '<img src="https://graph.facebook.com/' + response.id + '/picture" style="margin-right:5px"/>' + response.name;
alert(response.name);
document.getElementById('fb-root').appendChild(userInfo);
});
} else if (response.status === 'not_authorized') {
// not_authorized
alert("not_authorized");
} else {
// not_logged_in
alert("not_logged_in");
}
});
FB.Event.subscribe('{% if current_user %}auth.logout{% else %}auth.login{% endif %}', function(response) {
{% if current_user %} window.location = "/logout" {% else %} window.location.reload(); {% endif %}
});
};
(function() {
var e = document.createElement('script');
e.type = 'text/javascript';
e.src = document.location.protocol + '//connect.facebook.net/en_US/all.js';
e.async = true;
document.getElementById('fb-root').appendChild(e);
}());
</script>
所以,
如何使用 javascript 传递参数并将数据安全地插入数据存储区。例如,Response.name。同样在facebook登录。我意识到他们使用令牌进行登录响应,它也在他们的 python facebook 示例数据存储中。但是我创建了自己的登录系统,所以我认为我根本不需要使用那个令牌。根本不使用该令牌是否有任何风险?