使用Facebook PHP SDK v5注销

使用Facebook PHP SDK v5注销,php,facebook,cookies,login,logout,Php,Facebook,Cookies,Login,Logout,我使用的是Facebook SDK v5,我可以使用此脚本登录,登录时我创建了一个cookie,如果我试图通过清除该cookie来注销,则不可能 这是我的登录脚本 <?php require_once __DIR__ . '/src/Facebook/autoload.php'; require_once $_SERVER['DOCUMENT_ROOT'].'/fbloging/helper/helper.php'; $fb = new Facebook\Facebook([ 'app_i

我使用的是Facebook SDK v5,我可以使用此脚本登录,登录时我创建了一个cookie,如果我试图通过清除该cookie来注销,则不可能

这是我的登录脚本

<?php
require_once __DIR__ . '/src/Facebook/autoload.php';
require_once $_SERVER['DOCUMENT_ROOT'].'/fbloging/helper/helper.php';
$fb = new Facebook\Facebook([
'app_id' => '__MY_APP_ID__',
'app_secret' => '__MY_APP_SECRET__',
'default_graph_version' => 'v2.5'
]);

$helper = $fb->getJavaScriptHelper();

try {
$accessToken = $helper->getAccessToken();
} catch(Facebook\Exceptions\FacebookResponseException $e) {
// When Graph returns an error
echo 'Graph returned an error: ' . $e->getMessage();
} catch(Facebook\Exceptions\FacebookSDKException $e) {
// When validation fails or other local issues
echo 'Facebook SDK returned an error: ' . $e->getMessage();
}

if (isset($accessToken)) {
$fb->setDefaultAccessToken($accessToken);

try {

$requestProfile = $fb->get("/me?fields=name,email,id,picture.width(800).height(800),cover.width(300).height(175)");
$profile = $requestProfile->getGraphNode()->asArray();
} catch(Facebook\Exceptions\FacebookResponseException $e) {
// When Graph returns an error
echo 'Graph returned an error: ' . $e->getMessage();
} catch(Facebook\Exceptions\FacebookSDKException $e) {
// When validation fails or other local issues
echo 'Facebook SDK returned an error: ' . $e->getMessage();
}


$query = "SELECT * FROM `users` WHERE `user_id`='".$profile['id']."' AND `email`='".$profile['email']."'";
$result = $db->query($query);
$fr = mysqli_fetch_assoc($result);
if(mysqli_num_rows($result)>0){
if($fr['profile']==1){
set_user_cookie($profile['name'],$profile['id'],$profile['picture']['url'],$profile['email'],$profile['cover']['source']);
header('location: ../home.php');
}else{
set_user_cookie($profile['name'],$profile['id'],$profile['picture']['url'],$profile['email'],$profile['cover']['source']);
header('location: ../complete-profile.php');
}

}else{
$name = $profile['name'];
$id = $profile['id'];
$email = $profile['email'];
$result = $db->query("INSERT INTO `users`(`user_id`, `email`, `user_name`) VALUES ('$id','$email','$name')");
if($result){
set_user_cookie($name,$id,$profile['picture']['url'],$email,$profile['cover']['source']);
header('location: ../complete-profile.php');
}else{
echo 'Something Went Wrong';
}
}

// setcookie('user',$profile['name']."~".$profile['id']."~".$profile['picture']['url']."~".$profile['email'], time()+3600+2,"/");
// header('location: ../');
exit;
} else {
echo "Unauthorized access!!!";
exit;
}
我正在使用Cookie存储一些用户数据,以便在用户登录到文件时显示这些详细信息。当COOKIE设置为这样时,我需要用户可以访问该页面

complete profile.php

// Set cookie
function set_user_cookie($name, $id, $pro, $email,$cover){
$string=$name."~".$id."~".$pro."~".$email."~".$cover;
setcookie('udet',$string, time()+3600*2*24,"/");
}
require_once 'helper/helper.php';
if (isset($_COOKIE['udet'])) {
$user = explode("~",$_COOKIE['udet']);
$name =  $user[0];
$id = $user[1];
$pic = $user[2];
$email = $user[3];
$cover = $user[4];
}else{
header('Location : index.php');
}
<?php
unset($_COOKIE['udet']);
header('Location: index.php')
?>
我设置了一个注销链接,在注销文件中,我只是像这样删除cookie

logout.php

// Set cookie
function set_user_cookie($name, $id, $pro, $email,$cover){
$string=$name."~".$id."~".$pro."~".$email."~".$cover;
setcookie('udet',$string, time()+3600*2*24,"/");
}
require_once 'helper/helper.php';
if (isset($_COOKIE['udet'])) {
$user = explode("~",$_COOKIE['udet']);
$name =  $user[0];
$id = $user[1];
$pic = $user[2];
$email = $user[3];
$cover = $user[4];
}else{
header('Location : index.php');
}
<?php
unset($_COOKIE['udet']);
header('Location: index.php')
?>

但删除后,我也可以访问这些用户数据,facebook帐户不会注销

我搜索了这个答案,但在网上没有找到任何正确的答案

我需要在用户单击注销URL时注销用户(注销URL访问logout.php)


请帮帮我,大约一年前,我试着实现和你一样的目标

但如果我没记错的话,这是你无法控制的,只要用户登录到facebook,他就会“登录”到你的页面

您可以让他们进入登录页面,但facebook身份验证仍会识别他们,因为他们是在facebook登录的

我认为有一种方法可以让他们完全退出,但他们也会从facebook上退出,我不认为这会让你受欢迎

编辑:我查看了Facebook的JavaScript SDK中的注销方法,并引用了

方法FB.logout()将用户从您的站点注销,在某些情况下,还会注销Facebook


大约一年前,我试图实现和你一样的目标

但如果我没记错的话,这是你无法控制的,只要用户登录到facebook,他就会“登录”到你的页面

您可以让他们进入登录页面,但facebook身份验证仍会识别他们,因为他们是在facebook登录的

我认为有一种方法可以让他们完全退出,但他们也会从facebook上退出,我不认为这会让你受欢迎

编辑:我查看了Facebook的JavaScript SDK中的注销方法,并引用了

方法FB.logout()将用户从您的站点注销,在某些情况下,还会注销Facebook


所以,如果有人想从网站上注销,他也需要从facebook上注销,嗯,这不是一个好主意。我也注意到了php graph sdk中的这种行为。那么,我们怎么能只从网站而不是facebook上注销呢?所以,如果有人想从网站上注销,他也需要从facebook上注销,嗯,这不是一个好主意。我也注意到了php graph sdk中的这种行为。那我们怎么能只从网站上注销,而不从facebook上注销呢?