热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

PhpMyAdminSSO注销

如何解决《PhpMyAdminSSO注销》经验,应该怎么办?

我正在使用PhpMyAdmin和自定义单点登录(SSO)脚本直接登录界面.由我自己的系统给出一个唯一的登录令牌,PHP调用SSO脚本.此脚本在我的系统中查找唯一ID,以便检索MySQL用户名和密码,并将其返回给PhpMyAdmin.

到目前为止这是有效的,但我的下一个目标是在一定程度的不活动后自动注销.如果没有SSO,删除我的浏览器COOKIE并单击任何链接,我会进入登录页面,并显示消息»您的会话已过期.请再次登录.«.但是,我无法从我的SSO脚本中重现此行为.

这是我的SSO脚本:

 SESSION_TIMEOUT) {
        $sessiOnExpired= true;
    } else {
        $sessiOnExpired= false;
    }

    if (isset($query['old_usr'])) {
        /* logout and back to index page */
        unset($_SESSION['ssoLastActivity']);
        unset($_SESSION['ssoUser']);
        unset($_SESSION['ssoPassword']);
        header('Location: index.php');
        exit;
    }

    if ($sessionExpired) {
        unset($_SESSION['ssoLastActivity']);
        unset($_SESSION['ssoUser']);
        unset($_SESSION['ssoPassword']);

        /******** POINT OF QUESTION ********/
        /* I'm trying to give the same response as if the COOKIEs were deleted.
           I land on the login page as desired, however I'm missing the session
           timeout message. */
        header('Content-Type: application/json');
        echo json_encode(['redirect_flag' => '1', 'success' => false, 'error' => '']);
        exit;
        /***********************************/
    }

    /* update session activity timestamp */
    $_SESSION['ssoLastActivity'] = time();

    if (!empty($_SESSION['ssoUser']) && !empty($_SESSION['ssoPassword'])) {
        /* already logged in */
        return [
            $_SESSION['ssoUser'],
            $_SESSION['ssoPassword'],
        ];
    }

    /* retrieve MySQL login credentials here and store them in $user and $password */

    /* $user = ...; $password = ...; */

    return [
        $user,
        $password,
    ];
}

有没有人通过我的SSO脚本注销解决方案,这会导致我进入带有消息的登录页面,会话已过期?

更新:

该问题似乎与我的PhpMyAdmin服务器配置相关(在我的案例中为/etc/phpMyAdmin/servers.ini.php):

 array('auth_type' => 'signon', ..., 'SignonScript' => '/usr/share/phpMyAdmin/sso.php', 'SignonURL' => 'index.php?server=1'),
    2 => array('auth_type' => 'COOKIE', ...)
);

我在会话超时后检查了网络请求,事实证明,实际上有一个请求?session_expired=1(触发会话超时消息)发送到服务器1; 因为此脚本返回null(无登录),它重定向到SignonURL index.php?server = 1,省略额外的session_expired查询参数.

我可以通过&session_expired = 1扩展此URL ,但是这也会在定期注销时触发消息.

我愿意接受改善行为的任何想法.


推荐阅读
  • 欢乐的票圈重构之旅——RecyclerView的头尾布局增加
    项目重构的Git地址:https:github.comrazerdpFriendCircletreemain-dev项目同步更新的文集:http:www.jianshu.comno ... [详细]
  • 本文介绍了Redis的基础数据结构string的应用场景,并以面试的形式进行问答讲解,帮助读者更好地理解和应用Redis。同时,描述了一位面试者的心理状态和面试官的行为。 ... [详细]
  • Iamtryingtomakeaclassthatwillreadatextfileofnamesintoanarray,thenreturnthatarra ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • 开发笔记:Java是如何读取和写入浏览器Cookies的
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了Java是如何读取和写入浏览器Cookies的相关的知识,希望对你有一定的参考价值。首先我 ... [详细]
  • 本文介绍了如何使用C#制作Java+Mysql+Tomcat环境安装程序,实现一键式安装。通过将JDK、Mysql、Tomcat三者制作成一个安装包,解决了客户在安装软件时的复杂配置和繁琐问题,便于管理软件版本和系统集成。具体步骤包括配置JDK环境变量和安装Mysql服务,其中使用了MySQL Server 5.5社区版和my.ini文件。安装方法为通过命令行将目录转到mysql的bin目录下,执行mysqld --install MySQL5命令。 ... [详细]
  • 怎么在PHP项目中实现一个HTTP断点续传功能发布时间:2021-01-1916:26:06来源:亿速云阅读:96作者:Le ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • 如何在php文件中添加图片?
    本文详细解答了如何在php文件中添加图片的问题,包括插入图片的代码、使用PHPword在载入模板中插入图片的方法,以及使用gd库生成不同类型的图像文件的示例。同时还介绍了如何生成一个正方形文件的步骤。希望对大家有所帮助。 ... [详细]
  • Android实战——jsoup实现网络爬虫,糗事百科项目的起步
    本文介绍了Android实战中使用jsoup实现网络爬虫的方法,以糗事百科项目为例。对于初学者来说,数据源的缺乏是做项目的最大烦恼之一。本文讲述了如何使用网络爬虫获取数据,并以糗事百科作为练手项目。同时,提到了使用jsoup需要结合前端基础知识,以及如果学过JS的话可以更轻松地使用该框架。 ... [详细]
  • 本文介绍了NetCore WebAPI开发的探索过程,包括新建项目、运行接口获取数据、跨平台部署等。同时还提供了客户端访问代码示例,包括Post函数、服务器post地址、api参数等。详细讲解了部署模式选择、框架依赖和独立部署的区别,以及在Windows和Linux平台上的部署方法。 ... [详细]
  • 本文介绍了Web学习历程记录中关于Tomcat的基本概念和配置。首先解释了Web静态Web资源和动态Web资源的概念,以及C/S架构和B/S架构的区别。然后介绍了常见的Web服务器,包括Weblogic、WebSphere和Tomcat。接着详细讲解了Tomcat的虚拟主机、web应用和虚拟路径映射的概念和配置过程。最后简要介绍了http协议的作用。本文内容详实,适合初学者了解Tomcat的基础知识。 ... [详细]
  • 本文介绍了一种在PHP中对二维数组根据某个字段进行排序的方法,以年龄字段为例,按照倒序的方式进行排序,并给出了具体的代码实现。 ... [详细]
author-avatar
仲颖凯翰奕颖
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有