gpt4 book ai didi

javascript - HTML 5 中的 FB 登录按钮,带有 JS 重定向

转载 作者:行者123 更新时间:2023-11-28 02:24:35 25 4
gpt4 key购买 nike

在旧版本的 FB 登录按钮中,这对我来说效果很好

<fb:login-button scope='email,publish_stream'>Login</fb:login-button>
<div id='fb-root'></div>

<script type='text/javascript' src='http://connect.facebook.net/en_US/all.js'></script>
<script>window.fbAsyncInit = function() {FB.init({
appId: '<?php echo $facebook->getAppID(); ?>',
cookie: true,
xfbml: true,
oauth: true
});
FB.Event.subscribe('auth.login', function(response) {
window.location = '/fb_redirect.php';
});
FB.Event.subscribe('auth.logout', function(response) {
window.location.reload();
});
};
(function() {
var e = document.createElement('script');
e.async = true;e.src = document.location.protocol +'//connect.facebook.net/en_US/all.js';document.getElementById('fb-root').appendChild(e);}());
</script>

但是,我的一位 friend 最近建议切换到新的 HTML 5 登录按钮,如下所示:

  <div id='fb-root'></div>
<script>
(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/all.js#xfbml=1&appId=APPID';
fjs.parentNode.insertBefore(js, fjs);
}(document, 'script', 'facebook-jssdk'));
</script>

这也很有效。除了我找不到 JS 触发重定向到/fb_redirect.php 的方法。在旧的示例中,

FB.Event.subscribe('auth.login', function(response) {
window.location = '/fb_redirect.php';
});

工作得很好。但是,我需要将用户重定向到/fb_redirect.php,以便 PHP 可以启动 session 并将一些用户的 FB 信息插入到数据库中。

最佳答案

这是您的默认参数

<div id="fb-root"></div>
<script type="text/javascript">
window.fbAsyncInit = function() {
FB.init({
appId : <?php echo $facebook->getAppID() ?>,
status : false,
cookie : true,
xfbml : true
});
};

(function(d){
var js, id = 'facebook-jssdk', ref = d.getElementsByTagName('script')[0];
if (d.getElementById(id)) {return;}
js = d.createElement('script'); js.id = id; js.async = true;
js.src = "//connect.facebook.net/en_US/all.js";
ref.parentNode.insertBefore(js, ref);
}(document));

这是我的自定义fb_login函数,我的自定义函数fb_login()获取uid和accessToken值并执行其余操作。这次仅在单击登录按钮时才会发生。

function fb_login() {
FB.login(function(response) {
if (response.status === 'connected') {
var uid = response.authResponse.userID;
var accessToken = response.authResponse.accessToken;
if ((parseFloat(uid) == parseInt(uid)) && !isNaN(uid)) {
window.location = '/fb_redirect.php';

}
}
});
}

</script>

我用 onlogin 事件扩展了 FB 登录按钮,当用户单击使用 facebook 按钮登录并成功登录时,该事件会调用 JS 函数 fb_login()。

<div class="fb-login-button" onlogin="fb_login()"></div>

关于javascript - HTML 5 中的 FB 登录按钮,带有 JS 重定向,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15143486/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com