我已经SSO (Single Sign-On)
在我们的主站点和软件之间建立了一个系统,Invision Power Board
但我不确定当用户IPB
从主站点注销时如何注销?
此外,我需要在外部文件中加载哪些文件才能执行此操作?
我已经SSO (Single Sign-On)
在我们的主站点和软件之间建立了一个系统,Invision Power Board
但我不确定当用户IPB
从主站点注销时如何注销?
此外,我需要在外部文件中加载哪些文件才能执行此操作?
编辑:要为此使用 IPB 代码,您必须包括
require_once( IPS_ROOT_PATH . 'applications/core/modules_public/global/login.php' );
然后扩展public_core_global_login
并调用它的doLogout()
方法,你必须设置$this->member->setMember( $member_id );
我个人从来没有这样做过,所以下面是你如何手动做到这一点:
IPB 在会话中设置数据并存储几个用于自动登录的 cookie。您可以在不使用任何 IPB 源的情况下执行;你要做的是(注意 query 和 updatecookie 是一些伪函数,分别用于执行 DB 查询和设置 cookie 值):
query("DELETE FROM ".$ibf_prefix."sessions WHERE member_id = $userid");
updatecookie($ibf_cookieid."member_id",0,time()-1800);
updatecookie($ibf_cookieid."pass_hash",0,time()-1800);
updatecookie($ibf_cookieid."session_id",0,time()-1800);
您可以从 conf_global.php 读取 $ibf_prefix :
$ibf_prefix = $INFO[sql_tbl_prefix];
并且$ibf_cookieid
是:
$ibf_cache = query_first("SELECT cs_value FROM " . $ibf_prefix . "cache_store WHERE cs_key = 'settings'");
$ibf_cache = unserialize($ibf_cache['cs_value']);
$ibf_cookieid = $ibf_cache['cookie_id'];
您可以阅读doLogout
方法的来源admin/applications/core/modules_public/global/login.php
我不知道有任何 IPB API 用于此。
您可以尝试销毁会话session_destroy();
如果用户选中了“记住我”,您也必须删除 cookie pass_hash
。