后端开发|php教程
php, 单点登录, ucenter
后端开发-php教程
单点登录 Ucenter 原理分析
dll反编译成源码,vscode是万能的,华为ubuntu手机,tomcat改变路径吗,colly爬虫教程,Php编写xml,兰州站外seo优化工具,ssh2网站lzw
首先我们先来了解下 Ucenter登录步骤
php移动商城源码,vscode支持什么语言,ubuntu 应用管理,tomcat去掉80失败,sqlite3数据库签名,爬虫里的反爬虫机制,php代码怎么用,seo设计关键词,易语言写网站源码,ecshop 模板语法 iflzw
1、用户登录discuz,通过logging.php文件中的函数uc_user_login对post过来的数据进行验证,也就是对username和password进行验证。
c源码下载,vscode缩进参考线快捷设置,ubuntu平板系统,tomcat解析模板引擎,sqlite 时间存储,网页设计 发票,阿里云服务器优点,微信公众号运营插件,teambition前端框架,爬虫实操,php router,seo技巧让百度收录,基于springboot的书店,服务器系统搭建网站源码,爱心表白网页,如何介绍设计的网站模板下载,织梦后台一片空白,织梦更新页面,基于的管理系统源码下载,微信小程序 独立打包lzw
2、如果验证成功,将调用位于uc_client下client.php文件中的函数uc_user_synlogin,在这个函数中调用 uc_api_post(‘user’, ‘synlogin’, array(‘uid’=>$uid))。
3、然后这个函数后向Ucenter的index.php传递数据,index.php接受传递的数据,获得model为user,action为synlogin的值。
4、然后Ucenter的index.php调用control目录下的user.php类中的onsynlogin方法,通过foreach循环,以 javascript的方式通知uc应用列表中开启同步登陆的应用进行同步登录;即通过get方式传递给各个应用目录中api下的uc.php一些数据。
5、uc.php接收通知并处理get过来的数据,并在函数synlogin(位于uc.php中)通过函数_authcode加密数据(默认以UC_KEY作为密钥),用函数_setcookie设置cookie。
6、各个应用用对应的密钥解码上面设置的cookie,得到用户id等数据;通过这个值来判断用户是否经过其它应用登录过,从而让用户可以自动登陆。
应用程序的logging.php ——>uc_client中的client.php——>Ucenter——>应用程序中api/uc.php
其实Ucenter实现同步登陆的原理就是cookie,一个应用登陆成功之后,向Ucenter传递数据,让Ucenter通知其他的应用也设置 cookie,这样用户在访问其他应用的时候通过已经设置好的cookie实现自动登陆。了解了Ucenter的同步原理,再遇到无法同步登陆,或者开发 一些与UCenter接口的时候就会容易很多。
大致步骤 首先我们要先安装 ucenter 然后把uc_client 这个文件夹复制到自己的项目里面去 然后呢在配置几个文件
client.php相当于函数库
uc.php相当于回调文件
还有一个 config.inc.php 是配置文件
当你有2个应用都设置了同步登陆之后 当你登陆一个应用 然后执行
include ./config.inc.php; include ./uc_client/client.php; $usernames="feiye"; $passwords="789123"; list($uid, $username, $password, $email) = uc_user_login($usernames, $passwords);if($uid > 0) { setcookie("username",$username,time()+intval(24*3600));echo uc_user_synlogin($uid);echo 登录成功;} elseif($uid == -1) {echo 用户不存在,或者被删除;} elseif($uid == -2) {echo 密码错;} else {echo 未定义;}
uc_user_synlogin() 这个函数 代表着 要同步登陆到其他所有开启同步登陆的函数 uc自己会在后台把所有开启同步登陆的应用都给循环遍历一遍 然后 在页面上输出
类似这种的js代码 就是发送给每个开启同步登陆的应用 然后 每个开启同步登陆的应用 的 回调文件 uc.php 接受到后 会进行解密 解密好后 其实 你就可以自己来写代码了 这个uc.php回调文件的代码不一定非要按照他们的格式来写 你也可以自己写你自己的代码 比如说我就是根据session来做同步登陆的
function synlogin($get, $post) {$uid = $get[uid];$username = $get[username];if(!API_SYNLOGIN) {return API_RETURN_FORBIDDEN;}header(P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR");setcookie(gwyy,$username,time()+3600,/,127.0.0.71);_setcookie(Example_auth, _authcode($uid."\t".$username, ENCODE));$_SESSION[username] = $username;$_SESSION[uid]= $uid;}function synlogout($get, $post) {if(!API_SYNLOGOUT) {return API_RETURN_FORBIDDEN;}//note 同步登出 API 接口header(P3P: CP="CURa ADMa DEVa PSAo PSDo OUR BUS UNI PUR INT DEM STA PRE COM NAV OTC NOI DSP COR");_setcookie(Example_auth, \, -86400 * 365);unset($_SESSION[username]);unset($_SESSION[uid]);session_destroy();}
这样 当用户刷新了别的应用页面之后 就自动登陆了
注意 如果在UC里面添加应用 提示通信没有成功 那么原因很简单 就是没有找到你 http://xxxx/api/uc.php 这个文件 只要有这个文件在 那么通信 肯定会成功的
其实UC的原理很简单 就是某个应用登陆后 然后后台轮询发送给同步登陆的应用的回调文件 回调文件接收到用户ID之后 生成cookie或者session然后进入登陆模式。