ucenter通信原理分析
1、用戶登錄discuz,通過logging.php文件中的函數(shù)uc_user_login對post過來的數(shù)據(jù)進(jìn)行驗證,也就是對username和password進(jìn)行驗證。
2、如果驗證成功,將調(diào)用位于uc_client下client.php文件中的函數(shù)uc_user_synlogin,在這個函數(shù)中調(diào)用 uc_api_post(‘user', ‘synlogin', array(‘uid'=>$uid))。
3、然后這個函數(shù)后向Ucenter的index.php傳遞數(shù)據(jù),index.php接受傳遞的數(shù)據(jù),獲得model為user,action為synlogin的值。
4、然后Ucenter的index.php調(diào)用control目錄下的user.php類中的onsynlogin方法,通過foreach循環(huán),以javascript的方式通知uc應(yīng)用列表中開啟同步登陸的應(yīng)用進(jìn)行同步登錄;即通過get方式傳遞給各個應(yīng)用目錄中api下的uc.php一些數(shù)據(jù)。
5、uc.php接收通知并處理get過來的數(shù)據(jù),并在函數(shù)synlogin(位于uc.php中)通過函數(shù)_authcode加密數(shù)據(jù)(默認(rèn)以UC_KEY作為密鑰),用函數(shù)_setcookie設(shè)置cookie。
6、各個應(yīng)用用對應(yīng)的密鑰解碼上面設(shè)置的cookie,得到用戶id等數(shù)據(jù);通過這個值來判斷用戶是否經(jīng)過其它應(yīng)用登錄過,從而讓用戶可以自動登陸。
應(yīng)用程序的logging.php ——>uc_client中的client.php——>Ucenter——>其他應(yīng)用程序中的api/uc.php。
其實Ucenter實現(xiàn)同步登陸的原理就是cookie,一個應(yīng)用登陸成功之后,向Ucenter傳遞數(shù)據(jù),讓Ucenter通知其他的應(yīng)用也設(shè)置cookie,這樣用戶在訪問其他應(yīng)用的時候通過已經(jīng)設(shè)置好的cookie實現(xiàn)自動登陸。
大致步驟 ,首先要安裝 ucenter 然后把uc_client 這個文件夾復(fù)制到自己的項目里面去 ,然后呢在配置幾個文件
client.php相當(dāng)于函數(shù)庫
uc.php相當(dāng)于回調(diào)文件
config.php 是配置文件
當(dāng)你有2個應(yīng)用都設(shè)置了同步登陸之后 當(dāng)你登陸一個應(yīng)用 然后執(zhí)行
include ‘./config.inc.php';
include ‘./uc_client/client.php';
$usernames=”kyee”;
$passwords=”123456″;
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() 這個函數(shù) 代表著 要同步登陸到其他所有開啟同步登陸的函數(shù) uc自己會在后臺把所有開啟同步登陸的應(yīng)用都給循環(huán)遍歷一遍 然后 在頁面上輸出
<script type=”text/javascript” src=”http://www.lihuai.net/wp-content/uploads/sp/uc.php?time=1408327309&code=bc6bFLa6WH343nin2GAn%2F82Y9cnCennPk1gcLGYHdQF4wsXsOSdTyqBb2Nuoxe0UJqzWMWncdx%2FfQ1GK6FS%2BqJqi2AxVG2Oq1pD9c1wZy%2BgjXs7qo4mm2sxFVHwW7JnjKGPDkVdDqtYeybkSISz7yrdb0ZFuXH2yr3Cq” reload=”1″></script>
<script type=”text/javascript” src=”http://www.lihuai.net/wp-content/uploads/sp/uc.php?time=1408327309&code=206flCqeb%2Faft%2FDFPno9Bvqsb1b0o6XTZdIByOoD7EC11vMrjzC7PaKLo0LF3tGiHwlwZkwdW5VDHq866MGulsco5nekfkL341VWp7BPabnZPNtgG7m4jZpfdx6nVP0LTJLYI%2BkebI7uLm58atk8Ex4sKBj%2FfDkjH%2F8z” reload=”1″></script>
類似這種的js代碼 ,就是發(fā)送給每個開啟同步登陸的應(yīng)用, 然后每個開啟同步登陸的應(yīng)用的回調(diào)文件 uc.php 接受到后會進(jìn)行解密,解密好后其實你就可以自己來寫代碼了,這個uc.php回調(diào)文件的代碼不一定非要按照他們的格式來寫 ,你也可以自己寫你自己的代碼 。
其實UC的原理很簡單 ,就是某個應(yīng)用登陸后,然后后臺輪詢發(fā)送給同步登陸的應(yīng)用的回調(diào)文件 ,回調(diào)文件接收到用戶ID之后,生成cookie或者session然后進(jìn)入登陸模式。
- 簡單分析ucenter 會員同步登錄通信原理
- destoon整合UCenter圖文教程
- UCenter 批量添加用戶的php代碼
- UCenter中的一個可逆加密函數(shù)authcode函數(shù)代碼
- php將會員數(shù)據(jù)導(dǎo)入到ucenter的代碼
- UCenter Home二次開發(fā)指南
- php通過兩層過濾獲取留言內(nèi)容的方法
- thinkphp3.x中變量的獲取和過濾方法詳解
- PHP中字符安全過濾函數(shù)使用小結(jié)
- php完全過濾HTML,JS,CSS等標(biāo)簽
- PHP開發(fā)不能違背的安全規(guī)則 過濾用戶輸入
- ucenter中詞語過濾原理分析
相關(guān)文章
使用PHPMailer實現(xiàn)郵件的實時發(fā)送功能
這篇文章主要為大家詳細(xì)介紹了如何使用PHPMailer 實現(xiàn)一個接收詢盤并實時同步到指定郵箱的功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-12-12
php中把對象轉(zhuǎn)換為數(shù)組幾種簡單巧妙的方法
在PHP中,對象是一種復(fù)雜的數(shù)據(jù)類型,它可以包含多個屬性和方法,有時候我們需要將對象轉(zhuǎn)換為數(shù)組進(jìn)行操作,比如將對象存儲到數(shù)據(jù)庫中,或者將對象轉(zhuǎn)換為JSON格式等情況,對象轉(zhuǎn)數(shù)組不能用遞歸實現(xiàn)轉(zhuǎn)換,本文幾種簡單巧妙的方法2023-09-09
php + ajax 實現(xiàn)的寫入數(shù)據(jù)庫操作簡單示例
這篇文章主要介紹了php + ajax 實現(xiàn)的寫入數(shù)據(jù)庫操作,結(jié)合實例形式分析了php + ajax 寫入數(shù)據(jù)庫基本原理、操作技巧與相關(guān)使用注意事項,需要的朋友可以參考下2020-05-05
php實現(xiàn)可用于mysql,mssql,pg數(shù)據(jù)庫操作類
這篇文章主要介紹了php實現(xiàn)可用于mysql,mssql,pg數(shù)據(jù)庫操作類,以類的形式封裝了對mysql,mssql,pg三種數(shù)據(jù)庫的操作,非常具有實用價值,需要的朋友可以參考下2014-12-12
提高PHP性能的編碼技巧以及性能優(yōu)化詳細(xì)解析
include文件時盡量使用絕對路徑,因為它避免了PHP去include_path里查找文件的速度,解析操作系統(tǒng)路徑所需的時間會更少2013-08-08

