Ucenter 会员同步登录通讯原理

1,用户登录bbs,通过logging.php文件中,使用函数uc _user_login验证,如果验证成功,将调用函数 _user_synlogin(位于 uc_client下的client.php文件 中),在这个函数中调用uc _api_post(‘user‘, ‘synlogin‘, array(‘uid‘=>$uid));之后向 _API.‘/index.php‘传递了数据;这里的uc _API就是在 config.inc.php中的定义的 uc_server之URL地址

2, _server的index.php接受参数数据,获得model为user,action为synlogin,就调用control目录下的user.php类中的onsynlogin方法,通过foreach循环,以javascript的方式通知 应用列表中的应用同步登录;即通过get方式传递给应用目录中api下的uc .php一些数据;

3,uc .php接收通知并处理get过来的数据,并在函数synlogin(位于 uc.php中)通过函数uc_authcode加密数据(默认以 _KEY作为密钥),用函数uc_setcookie设置cookie;

4,各个应用在适当的文件中用对应的密钥解码上面设置的cookie,得到用户id等数据;通过这个值来判断用户是否经过其它应用登录过;

以discuz举例:

一、用户登录检查与用户登录验证logging.php

在bbs的logging.php中如下代码段

} elseif($action == ‘login‘) {

if($discuz_uid) {

$ synlogin = ‘‘;

showmessage(‘login_s ceed‘, $indexname);

}

检查用户id变量$discuz_uid是否为空来判断,用户是否登录(包括从别的应用登录。)

如果用户从bbs登录,则在登录验证成功后通过如下代码:

$ synlogin = $allowsynlogin ? uc_user_synlogin($discuz_uid) : ‘‘;

通知其它应用----“用户已从bbs登录,请通知其它应用设置cookie”

( _server通过javascript调用方式向其它应用的api/ uc.php传递数据)

可以在 应用目录下新建一个名为test.php的文件,来模拟登录成功,请求uc _server通知其它应用。文件内容为:

---------------------文件内容开始----------------------

<?php

include_once "config.inc.php";

include_once "./ _client/client.php";

echo uc _user_synlogin(1);

echo "<pre>";

var_dump($_COOKIE);

echo "</pre>";

?>

<script type="text/javascript">

var obj=document.getElementsByTagName("script");

for(var i=0;i<obj.length-1;i++) {

document.write("<a href=\""+obj[i].src+"\">"+obj[i].src+"</a><hr>");

}

</script>

---------------------文件内容结束----------------------

ps:这段测试代码还可以测试同步登录不好使的情况,具体使用方法,你可以思考一下(本文后面也有介绍),有问题可以在此文结尾发表评论与我讨论。

运行后,查看源代码即可看到javascript;

这里要注意了:这些javascript的通知中是不包含用户登录的应用的。也就 是说只"通知"用户未登录的应用,因为用户通过 _server登录成功的当前应用,当然不需要 _server再通知了。具体代码请参 看:webroot\ _server\control\user.php中的onsynlogin函数的这句:

if($app[‘synlogin‘] && $app[‘appid‘] != $this->app[‘appid‘])

代码解释:

$app[‘synlogin‘]是 应用是否允许同步登录

而且应用id不等于用户当前登录的应用id

$app数组就是uc _server\data\cache\apps.php中的数组$_CACHE[‘apps‘];

$this->app就是用户登录的应用

二、接受其它应用的同步登录通知:

在discuz的api目录下的 uc.php中的函数synlogin,在这里接受 uc_server发送过来的“同步登录通知”,并设置discuz的cookie,在这个函数中你可以查看到cookie的加密密钥的“算法”;

如果你想看看uc _server发送过的的“通知”是什么数据,你可以这么做:

1,修改要接受通知的应用目录下的api\uc .php,在$action = $get[‘action‘];代码下面添加如下代码:

echo "<pre>";var_dump($get);echo "</pre>";die("<hr>api\ uc.php");

2,将上面建立的test.php文件放置在其它允许同步登录的应用目录下,并在浏览器中运行,然后点击页面中对应第一步的应用链接,即可看到 uc_server“通知”给改应用的数据;

---------------------------分割线-------------------------------

function synlogin($get, $post)

在这个函数中通过uc_authcode函数,以密钥$discuz_auth_key加密了cookie;

在这里为了避免cookie名称冲突,在cookie名称(一般为:auth)前加了前缀($cookiepre),这个前缀也就是在config.inc.php中设置的那个cookie前缀值;

请看设置cookie的函数uc_setcookie:

(通过参数$prefix来判断是否对cookie名称添加前缀$cookiepre)

function uc_setcookie($var, $val, $life = 0, $prefix = 1) {

global $cookiepre, $cookiedomain, $cookiepath, $timestamp, $_SERVER;

setcookie(($prefix ? $cookiepre : ‘‘).$var, $val,

$life ? $timestamp + $life : 0, $cookiepath,

$cookiedomain, $_SERVER[‘SERVER_PORT‘] == 443 ? 1 : 0);

}

密钥“算法”:

$discuz_auth_key= md5($_DCACHE[‘settings‘][‘authkey‘].$_SERVER[‘HTTP_USER_AGENT‘]);

也就是不同用户加密cookie的密钥可能不同;

三、检查用户是否已登录(无论是那个应用下登录):

discuz的incl?目录中common.inc.php中有这样的代码:

$discuz_auth_key = md5($_DCACHE[‘settings‘][‘authkey‘].$_SERVER[‘HTTP_USER_AGENT‘]);

list($discuz_pw, $discuz_secqs, $discuz_uid) = empty($_DCOOKIE[‘auth‘]) ? array(‘‘, ‘‘, 0) : daddslashes(explode("\t", authcode($_DCOOKIE[‘auth‘], ‘DECODE‘)), 1);

这段代码就是解码在 .php中用密钥($discuz_auth_key)加密的 cookie值,以获得用户id($discuz_uid)这里的解密函数位于bbs\incl?\global.func.php中,虽然未给函数 传递cookie密钥,但函数中通过全局变量$GLOBALS[‘discuz_auth_key‘])获得密钥。

时间: 2024-08-28 08:10:31

Ucenter 会员同步登录通讯原理的相关文章

简单分析ucenter 会员同步登录通信原理

1.用户登录discuz,通过logging.php文件中的函数uc_user_login对post过来的数据进行验证,也就是对username和password进行验证. 2.如果验证成功,将调用位于uc_client下client.php文件中的函数uc_user_synlogin,在这个函数中调用 uc_api_post('user', 'synlogin', array('uid'=>$uid)). 3.然后这个函数后向Ucenter的index.php传递数据,index.php接受传

UCENTER同步登录工作原理和配置要点

ucenter的同步登录原理: 1)Ucenter是和uc_client同步的.每个PHP应用,加入了UCENTER后,都会在主目录下有个UC_CLIENT目录.这个目录里,都有一个client.PHP. 2)以我的应用例子来说,我的ecshop系统和discuz系统都加入了ucenter.则ecshop登录时,user.php中的login会检查配置文件,并根据配置最终调用uc_client\client.php中的uc_user_synlogin. 3)uc_user_synlogin会调用

ucenter 整合同步登录的内部实现原理及thinkphp整合ucenter

1.用户登录discuz,通过logging.php文件中的函数uc_user_login对post过来的数据进行验证,也就是对username和password进行验证.2.如果验证成功,将调用位于uc_client下client.php文件中的函数uc_user_synlogin,在这个函数中调用 uc_api_post('user', 'synlogin', array('uid'=>$uid)).3.然后这个函数后向Ucenter的index.php传递数据,index.php接受传递的

ucenter 整合同步登录的内部实现原理

1.用户登录discuz,通过logging.php文件中的函数uc_user_login对post过来的数据进行验证,也就是对username和password进行验证. 2.如果验证成功,将调用位于uc_client下client.php文件中的函数uc_user_synlogin,在这个函数中调用 uc_api_post('user', 'synlogin', array('uid'=>$uid)). 3.然后这个函数后向Ucenter的index.php传递数据,index.php接受传

解决整合 UCenter 首次注册同步登录与自动激活

多程序整合 UCenter,在新用户首次注册后是没有同步登录到其它程序的,也就是说用户得在其它程序用密码再登录一次,以后才能同步登录,还有就是用户不是在 Discuz 程序注册的话,在 Discuz 登录时得手动激活,这些都导致用户体验很不好,不过解决方法很简单~修改各个程序目录下的 ./uc_client/model/user.php 文件,大概在 129 行处的 function add_user 函数里添加代码如 Discuz X 的: $this->db->query("IN

ucenter通信实现同步登录、同步退出(详细)

首先,需要去官网下载一个ucenter的包.然后解压下来. 先把ucenter/ucenter这个文件夹复制到你的项目根目录下改名为uc_server;(这里只是我建议修改,以便于我下面写的配置); 然后将ucenter/advanced/uc_client复制粘贴到自己的项目上. 在你项目根目录创建一个api的文件夹.把ucenter/advanced/examples/api里头有个uc.PHP复制到你项目的api文件夹下. 其次同样,ucenter/advanced/examples把in

discuz Ucenter第三方双向同步登录

今天按照官网的例子 把ucenter弄下来了,直接用官网的例子,用户注册登录的什么都好使.就是不不能同步登录. 研究了好久才发现  Ucenter_client的注册用户只增加在 pre_ucenter_members 表的的,所以你用ucenter的登录接口可以登录成功,但是 .$ucsynlogin  这个是返回空的,正常应该返回一串javascript来设置cookies,这样discuz也就自动同步登录的. 用接口注册的用户,你去discuz用户管理哪里是看不到的,这个时候新增一个同名的

ucenter 同步登录总结

部署: discuz默认安装后就安装了uc_server应用 各应用根目录必须有uc_client文件夹. 下载ucenter程序查看范例程序 应用管理中,应用的主 URL必须指向到应用的根目录,应用接口文件名称,不含路径,默认为uc.php(默认在根目录的api目录下),从而程序会组成 http://localhost/api/uc.php 地址 应用的 UCenter 配置信息:最好和程序中的 config_xxx.php 文件对比下是否是程序自动生成的内容. 可能遇到的问题如下: Disc

一个进程间同步和通讯的 C# 框架

转自原文 一个进程间同步和通讯的 C# 框架 threadmsg_demo.zip ~ 41KB    下载 threadmsg_src.zip ~ 65KB    下载 0.背景简介 微软在 .NET 框架中提供了多种实用的线程同步手段,其中包括 monitor 类及 reader-writer锁.但跨进程的同步方法还是非常欠缺.另外,目前也没有方便的线程间及进程间传递消息的方法.例如C/S和SOA,又或者生产者/消费者模式中就常常需要传递消息.为此我编写了一个独立完整的框架,实现了跨线程和跨