私はこれに何時間も苦労してきました...
サイトに [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 タグに含まれています。
私は何が欠けていますか?