取消设置 $_SESSION 不起作用

2024-02-15

嗨,我编写了一个与 facebook 连接并注册用户的代码,然后它使用户登录,一切都很好。.当他们登录时,我设置

$_SESSION['id']

我的猜测是,如果未设置此设置,用户将从我的网站注销,并且不会“自动重新连接”。

因为以前它就像一个循环,每次我注销时,它都会使用 facebook 连接再次登录,即使用户没有再次点击“使用 facebook 登录”...

编辑:我更改了条件并且知道不是“循环”我可以注销该网站。

但是 Session 并没有被取消设置!为什么,只是 cookie 设置为 '' 但是,=( 会话没有被取消设置

这是我的代码

头部

<?php
//
// uses the PHP SDK. Download from https://github.com/facebook/php-sdk
include("facebook-php-sdk-master/src/facebook.php");

//
// from the facebook app page
define('YOUR_APP_ID', '');
define('YOUR_APP_SECRET', '');

//
// new facebook object to interact with facebook
$facebook = new Facebook(array(
 'appId' => YOUR_APP_ID,
 'secret' => YOUR_APP_SECRET,
));
//
// if user is logged in on facebook and already gave permissions
// to your app, get his data:
$userId = $facebook->getUser();

?>

The body

<?php
echo $_SESSION['id'];

if ($userId) {
 //
 // already logged? show some data
 $userInfo = $facebook->api('/' + $userId);





 if (isset($userInfo['email']) || isset($_SESSION['id']))

{ include "facebookregister.php"; } else { echo "no hay permisos de facebook"; }

} else {
 //
 // use javaascript api to open dialogue and perform
 // the facebook connect process by inserting the fb:login-button
 ?>
 <div id="fb-root"></div>
 <fb:login-button scope='email,user_birthday'></fb:login-button>
 <?php
}
?>
 <script>
 window.fbAsyncInit = function() {
 FB.init({
 appId : <?=YOUR_APP_ID?>,
 status : true,
 cookie : true,
 xfbml : true,
 oauth : true,
 });


FB.Event.subscribe('auth.login', function(response) {
 // ------------------------------------------------------
 // This is the callback if everything is ok
 window.location.reload();
 });
 };

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

facebook注册.php

<?PHP 
echo "<p>YOU ARE: <strong>". $userInfo['name'] ."</strong><br/>";
echo "Your birth date is: ".$userInfo['birthday']."</p>";
echo "Your mail is: ".$userInfo['email']."</p>";

echo "Your mail is: ".$userInfo['username']."</p>";



//$name = $userInfo['name'];
$first_name = $userInfo['first_name'];
$last_name = $userInfo['last_name'];
$birthday = $userInfo['birthday'];
$username_fb = $userInfo['username'];
$email = $userInfo['email'];
$gender = $userInfo['gender'];
$status = 1;

function generateRandomString($length = 10) {
    $characters = '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ!';
    $randomString = '';
    for ($i = 0; $i < $length; $i++) {
        $randomString .= $characters[rand(0, strlen($characters) - 1)];
    }
    return $randomString;
}


    $db= DAL::get_instance();           



    //select all rows from our users table where the emails match
                                    $count=$db->read_single_column("select count(id) from ".TABLE_PREFIX."users where email=? and status=1", array($email));
 echo "Aqui".$count;
                                    //if the number of matchs is 1
                                    if($count == 1){
                                        //the email address supplied is taken so just login user 


                                    $res=$db->execute_query("select * from ".TABLE_PREFIX."users where email=?",array($email));
                    $v=$res->fetch_assoc();
                    $username=$v['username'];
                    $password=$v['password'];



            $this->set_variable('username',$username);
                    $this->set_variable('password',$password);


                    $query="select id from ".TABLE_PREFIX."users where username=? and password=?";
                    $res=$db->execute_query($query,array($username,$password));

                    $value2=$res->fetch_assoc();
                    $id=$value2['id'];
                    $orig_password=$db->read_single_column("select password from ".TABLE_PREFIX."users where username=? and status=1", array($username));




                    if($password == $orig_password)
                    {
                        $t=time();
                        $sql="update ".TABLE_PREFIX."users set last_login_time=? where id=?";
                        $res=$db->execute_query($sql,array($t,$id));




                        $srv_nms=BASE;
                        $srv_nms=str_replace("http://","",$srv_nms);
                        $srv_nms=str_replace("https://","",$srv_nms);
                        $srv_nms=str_replace("www.","",$srv_nms);


                        $srv_pats=$srv_nms;

                        $srv_nms_arr=explode("/",$srv_nms);
                        $srv_nms=$srv_nms_arr[0];


                        $srv_pats=str_replace($srv_nms."/","",$srv_pats);


                        setcookie(COOKIE_LOGINID,$id,0,"/".$srv_pats,$srv_nms);
                        setcookie(COOKIE_USERNAME,$username,0,"/".$srv_pats,$srv_nms);
                        setcookie(COOKIE_PASSWORD,$orig_password,0,"/".$srv_pats,$srv_nms);
                            $_SESSION['user'] = $email;
                        $_SESSION['id'] = $id;          

        if(LoginHelper::validate_user_login()==0)
        {
            header("Location:index.php");
            exit;
        }


        }


                                    }else{

    //finally, otherwise register there account

                                        //time of register (unix)
                                        $registerTime = date('U');

                                        //make a code for our activation key
                                        $code = md5($username).$registerTime;

                                            $password = $randomString;

                                        $password  = md5($password);

                                        //insert the row into the database
                                         $res=$db->execute_query("INSERT INTO ".TABLE_PREFIX."users (`username`, `password`, `email`, `reg_time`, `status`, `fname`, `lname`) VALUES('".$username_fb."','".$password."','".$email."','".$registerTime."','".$status."','".$first_name."' ,'".$last_name."'  )");

                                        $row=$db->execute_query("SELECT username, password FROM ".TABLE_PREFIX."users WHERE email=".$email."");
                $row_data=$row->fetch_assoc();

                $username=$row_data['username'];
                $password=$row_data['password'];


            $this->set_variable('username',$username);
                    $this->set_variable('password',$password);


                    $query="select id from ".TABLE_PREFIX."users where username=? and password=?";
                    $res=$db->execute_query($query,array($username,$password));

                    $value2=$res->fetch_assoc();
                    $id=$value2['id'];
                    $orig_password=$db->read_single_column("select password from ".TABLE_PREFIX."users where username=? and status=1", array($username));


                    if(md5($password)== $orig_password)
                    {
                        $t=time();
                        $sql="update ".TABLE_PREFIX."users set last_login_time=? where id=?";
                        $res=$db->execute_query($sql,array($t,$id));




                        $srv_nms=BASE;
                        $srv_nms=str_replace("http://","",$srv_nms);
                        $srv_nms=str_replace("https://","",$srv_nms);
                        $srv_nms=str_replace("www.","",$srv_nms);


                        $srv_pats=$srv_nms;

                        $srv_nms_arr=explode("/",$srv_nms);
                        $srv_nms=$srv_nms_arr[0];


                        $srv_pats=str_replace($srv_nms."/","",$srv_pats);


                        setcookie(COOKIE_LOGINID,$id,0,"/".$srv_pats,$srv_nms);
                        setcookie(COOKIE_USERNAME,$username,0,"/".$srv_pats,$srv_nms);
                        setcookie(COOKIE_PASSWORD,$orig_password,0,"/".$srv_pats,$srv_nms);

                        $_SESSION['user'] = $email;
                        $_SESSION['id'] = $id;              



            //header("Location:".$this->make_url('user/home'));
            //exit;

                }                       


                                        //send the email with an email containing the activation link to the supplied email address
                                        mail($email, $username.' registration confirmation', "Thank you for registering to us ".$username.",\n\nHere is your activation link. If the link doesn't work copy and paste it into your browser address bar.\n\nhttp://www.yourwebsitehere.co.uk/activate.php?code=".$code, 'From: [email protected] /cdn-cgi/l/email-protection');

                                        //display the success message
                                        echo "<center>You have successfully registered, please visit you inbox to activate your account!</center>";


            header("Location: index.php");
            exit;
                                    }







        ?>

最重要的。注销操作

function logout_action()
    {
        $srv_nms=BASE;
        $srv_nms=str_replace("http://","",$srv_nms);
        $srv_nms=str_replace("https://","",$srv_nms);
        $srv_nms=str_replace("www.","",$srv_nms);


        $srv_pats=$srv_nms;

        $srv_nms_arr=explode("/",$srv_nms);
        $srv_nms=$srv_nms_arr[0];


        $srv_pats=str_replace($srv_nms."/","",$srv_pats);


        setcookie(COOKIE_LOGINID,"",0,"/".$srv_pats,$srv_nms);
        setcookie(COOKIE_USERNAME,"",0,"/".$srv_pats,$srv_nms);
        setcookie(COOKIE_PASSWORD,"",0,"/".$srv_pats,$srv_nms);

        unset($_SESSION['user']);
unset($_SESSION['id']);
unset($_SESSION['fb_540341239342331_code']);
unset($_SESSION['fb_540341239342331_access_token']);
unset($_SESSION['fb_540341239342331_user_id']);


        header("Location: ".$this->make_url("user/login/l"));
        die;
    }

会话取消设置并销毁,经过测试但不起作用..为什么? 代码

function logout_action()

{
    $srv_nms=BASE;
    $srv_nms=str_replace("http://","",$srv_nms);
    $srv_nms=str_replace("https://","",$srv_nms);
    $srv_nms=str_replace("www.","",$srv_nms);


    $srv_pats=$srv_nms;

    $srv_nms_arr=explode("/",$srv_nms);
    $srv_nms=$srv_nms_arr[0];


    $srv_pats=str_replace($srv_nms."/","",$srv_pats);


    setcookie(COOKIE_LOGINID,"",0,"/".$srv_pats,$srv_nms);
    setcookie(COOKIE_USERNAME,"",0,"/".$srv_pats,$srv_nms);
    setcookie(COOKIE_PASSWORD,"",0,"/".$srv_pats,$srv_nms);

    session_unset();


    header("Location: ".$this->make_url("user/login/l"));
    die;
}

不建议以这种方式取消设置会话变量。使用session_unset(), see http://php.net/manual/en/function.session-unset.php http://php.net/manual/en/function.session-unset.php

除此之外,您不希望会话仍然存在于用户计算机上,用于此用途session_destroy().

session_unset()只是清除会话以供使用。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

取消设置 $_SESSION 不起作用 的相关文章

  • 如何将 MySQL 数据库更改为 UTC?

    我使用的是 Windows 7 对数据库方面的东西有点陌生 我尝试在 Google 上搜索如何将系统时区更改为 UTC 但文档有些高级 我不太确定如何更改此字段 在 my ini 文件的 mysqld 部分下 添加以下行 default t
  • Symfony2 功能测试会话持久性

    我正在尝试在 Symfony 中进行一些功能测试 但目前我的会话遇到了问题 我执行了一段代码 它似乎有效 但容器的会话中没有存储任何内容 我有一个表格 您可以在其中设置数据 当您提交它时 它会检查值并将其存储在会话中 然后它重定向到另一个页
  • 安装 Symfony 2.4.1 lib-icu 4.4 依赖项时出现问题

    我遇到了与以下相同的问题this one https stackoverflow com questions 16753105 problems with lib icu dependency when installing symfony
  • 将记录分成两列

    我的数据库中有一个 学生 表 其中包含大约 5 000 条记录 我想将这些记录显示在two分区 如何在不执行查询两次的情况下做到这一点 仅使用单个查询 显示示例http www freeimagehosting net uploads f1
  • 如何修复网站 iframe 错误?

    当我访问此网址时 警告 推荐使用一些广告拦截器 网页链接加载良好 没有错误 但是 当我尝试通过加载同一页面时iframe在我的html代码中 出现错误 我的html代码
  • jQuery id 选择器在有 .在 ID 中[重复]

    这个问题在这里已经有答案了 我的html代码如下 div class chatbox html markup which is validated div 在上面的代码中dipesh parmardiv 动态添加 我正在使用以下代码访问它
  • Magento - 当我的订单取消或退款时如何运行代码

    如果订单被取消或退款 我的支付模块需要向支付服务发送通知 我假设订单页面 在管理后端 上的 取消 按钮将取消订单 而 贷项通知单 按钮 创建发票后 将退还订单 如何针对这些事件运行我的代码 我尝试在付款方式模型中使用 cancel 方法 但
  • Facebook 好友请求 - 失踪好友

    我请求从我正在开发的 Android 应用程序中获取用户好友 从 Facebook Api V2 0 开始 我知道我应该只获取已经通过我的应用程序登录的用户好友 但是 尽管我知道用户的某些朋友已通过我的应用程序登录 但在请求该用户的朋友时
  • TCPDF UTF-8 符号未显示

    我使用最新的 TCPDF 版本 5 9 但在编码方面遇到一些奇怪的问题 我需要立陶宛语语言符号 例如 但只能得到其中的一小部分 其他的还是这样 所以我该怎么做 我使用默认的 times 字体 它带有 TCPDF 下载 任何帮助 将不胜感激
  • Symfony2 Twig 扩展

    我在实现树枝扩展时遇到一些问题 我需要创建自己的过滤器 子过滤器 所以我想到了使用twig扩展 我在 MyApp Bundle WebsiteBundle 和文件上创建了一个名为 Extension 的文件夹 网站扩展 php namesp
  • 如何有效地从 DB2 表中删除所有行

    我有一个大约有 50 万行的表 我想删除所有行 如果我做简单的delete from tbl 事务日志已满 我不关心这种情况下的事务 无论如何我都不想回滚 我可以删除许多事务中的行 但是有更好的方法吗 如何有效地从 DB2 中的表中删除所有
  • PDO SQLSRV 和 PDO MySQL 在获取 int 或 float 时返回字符串

    当您获取时 PDO MS SQL Server 和 PDO MySQL 都会返回一个字符串数组 即使列的 SQL 类型本应是数字类型 例如 int 或 float 我设法解决了这个问题 但我想了解为什么它们一开始就这样设计 是不是因为PDO
  • 使 pdo::query 静态

    当我运行下面的代码时出现此错误 我通常使用 msql 函数 但我尝试使用 PDO 代替 怎么了 致命错误 第 14 行无法静态调用非静态方法 PDO query
  • PHP - Filter_var 替代方案?

    我构建了一个 php 脚本来输出以表单形式发布的数据 但遇到了问题 网站将运行的服务器运行 PHP 5 1 6 此版本的 PHP 不支持 filter var 我需要知道短期内的替代方案 最好是昨天 但在 Google 或 Stack Ov
  • 自定义 WP 主题时,我应该将导航栏放在“”标签之前还是之后?

    我正在通过制作子主题来自定义 WP 主题 我将 Bootstrap 中的导航栏放入子主题目录中的 header php 文件中 但是 我不确定在哪里放置导航栏代码 我可以把它都放在前面and之后标记成功 例如 无论我选择哪一个 导航栏都显示
  • SQL参数化查询不显示结果

    我的 DataAcess 类中有以下函数 但它没有显示任何结果 我的代码如下 public List
  • 获取家庭成员

    假设以下家庭 其构建架构是 create table PersonConn child int parent int insert into PersonConn values 1 2 insert into PersonConn valu
  • 查询中列的顺序重要吗?

    当从 MySQL 表中选择列时 与表中的顺序相比 选择列的顺序是否会影响性能 不考虑可能覆盖列的索引 例如 您有一个包含行 uid name bday 的表 并且有以下查询 SELECT uid name bday FROM table M
  • 如何复制 ArrayIterator 以保留其当前迭代位置?

    因为这似乎是我必须做的才能达到这种效果 arr a gt first b gt second iter new ArrayIterator arr Do a bunch of iterations iter gt next new iter
  • 将 SQL 数据中的一行映射到 Java 对象

    我有一个 Java 类 其实例字段 以及匹配的 setter 方法 与 SQL 数据库表的列名相匹配 我想优雅地从表中获取一行 到 ResultSet 中 并将其映射到此类的实例 例如 我有一个 Student 类 其中包含实例字段 FNA

随机推荐