0

私はこれに何時間も苦労してきました...

サイトに [Facebook でログイン] ボタンがあり、認証済みのユーザー データをデータベースに追加しようとしています。新鮮な目が私の間違いを見つけてくれることを願っているので、ここに私が持っているものがあります.

<div id="fb-root"></div>
<script>
window.fbAsyncInit = function() {
    FB.init({
        appId   : 'MY APP ID',
        oauth   : true,
        status  : true, // check login status
        cookie  : true, // enable cookies to allow the server to access the session
        xfbml   : true // parse XFBML
    });

  };

function fb_login(){
    FB.login(function(response) {

        if (response.authResponse) {
            console.log('Welcome!  Fetching your information.... ');
            //console.log(response); // dump complete info
            access_token = response.authResponse.accessToken; //get access token
            user_id = response.authResponse.userID; //get FB UID

            FB.api('/me', function(response) {
                 $.post("addtodb.php", {name: response.name})
            });

            window.location.href = "next.php"; //redirect once authorized

            FB.api('/me/devlogintest:join', 'action', 
            { object : 'http://www.mysite.com' });

        } else {
            //user hit cancel button
            console.log('User cancelled login or did not fully authorize.');

        }
    }, {
        scope: 'email,publish_actions'
    }
    );
}
(function() {
    var e = document.createElement('script');
    e.src = document.location.protocol + '//connect.facebook.net/en_US/all.js';
    e.async = true;
    document.getElementById('fb-root').appendChild(e);
}());
</script>

addtodb.php スクリプト...

<?php

include('config.php');
$fbname = $_POST['name'];

if(!empty($_POST)){ //won't submit blanks if no data

// Make a MySQL Connection
mysql_connect($Host,$Username,$Password) or die(mysql_error());
mysql_select_db($Database) or die(mysql_error());

// Insert rows
mysql_query("INSERT INTO fbusers 
(name) VALUES('$fbname') ") 
or die(mysql_error());  
}
?>

ユーザーの名前を Post に取得してデータベースに追加できないようです。JavaScript でアラートを使用すると、正しい情報がポップアップ表示されます。エラーチェックを有効にすると、phpスクリプト側にもエラーはないようです。

jquery 呼び出しは head タグに含まれています。

私は何が欠けていますか?

4

1 に答える 1

2

コードの主要な問題の 1 つは、非同期コードを実行した直後にリダイレクトを使用することです...非同期FB.apiで動作するため、データが返されたり、データがサーバーに送信されたりする前に$.postリダイレクトが発生する可能性があります。next.phpFB.api$.post

コメントで述べたように、定義されていないという$results = mysql_query($query) or die("Error: " . mysql_error());警告が表示され、空のクエリが発生します。$queryスクリプトが呼び出された場合 (そうではない可能性があります)、ログにその警告が表示されます (エラー レポートが有効になっています)。

リダイレクト コードを のコールバック関数内に移動して$.post、スクリプトがデータを受信するまで待機するようにしてください。

于 2012-05-06T07:17:13.497 に答える