我正在使用社交登录。我尝试使用 facebook 登录。一旦用户通过身份验证,我就可以获得他们的价值,我需要在 cookie 中设置他们的 id,以便我可以跨站点创建会话。
这是我的代码,
<?php
/*
* login_with_facebook.php
*
* @(#) $Id: login_with_facebook.php,v 1.2 2012/10/05 09:22:40 mlemos Exp $
*
*/
require('http.php');
require('oauth_client.php');
$client = new oauth_client_class;
$client->server = 'Facebook';
$client->redirect_uri = 'http://'.$_SERVER['HTTP_HOST'].
dirname(strtok($_SERVER['REQUEST_URI'],'?')).'/login_with_facebook.php';
$client->client_id = ''; $application_line = __LINE__;
$client->client_secret = '';
if(strlen($client->client_id) == 0
|| strlen($client->client_secret) == 0)
die('Please go to Facebook Apps page https://developers.facebook.com/apps , '.
'create an application, and in the line '.$application_line.
' set the client_id to App ID/API Key and client_secret with App Secret');
/* API permissions
*/
$client->scope = 'email';
if(($success = $client->Initialize()))
{
if(($success = $client->Process()))
{
if(strlen($client->access_token))
{
$success = $client->CallAPI(
'https://graph.facebook.com/me',
'GET', array(), array('FailOnAccessError'=>true), $user);
}
}
$success = $client->Finalize($success);
}
if($client->exit)
exit;
if($success)
{
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>Facebook OAuth client results</title>
</head>
<body>
<?php
echo "This is id i got from facebook ".$user->id." I am unable to set this value in cookie.";
mysql_connect('localhost', 'user_id', 'pwd');
mysql_select_db("DB Name");
$sql = "INSERT INTO oauth SET auth_id = ".$user->id.",
name = '".$user->name."',
email = '".$user->email."',
link = '".$user->link."'";
mysql_query($sql);
if(isset($_COOKIE['auth_id']))
unset($_COOKIE['auth_id']);
setcookie("auth_id", $user->id, time()+60*60*24, "/");
?>
<script>
//window.close();
</script>
</body>
</html>
<?php
}
else
{
?>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>OAuth client error</title>
</head>
<body>
<h1>OAuth client error</h1>
<pre>Error: <?php echo HtmlSpecialChars($client->error); ?></pre>
</body>
</html>
<?php
}
?>
只需在更新我的域后设置 cookie。但这对我不起作用。