關于DISCUZ不用通行證登陸得內(nèi)容介紹第2/2頁
更新時間:2008年10月04日 15:56:39 作者:
DISCUZ是中國最常用的論壇,雖然他本身有通行證給大家連接,但實際上用戶的統(tǒng)一還是很不好,經(jīng)常要建立兩個用戶表,第一不利于注冊和管理,第二浪費數(shù)據(jù)庫。
我們var_dump($_COOKIE)一下,發(fā)現(xiàn)顯示的是:array(5) { ["eVb_cookietime"]=> string(7) "2592000" ["eVb_oldtopics"]=> string(3) "D1D" ["eVb_sid"]=> string(6) "HfxRDJ" ["eVb_auth"]=> string(68) "LSwuxyf7QECdnc+9AxgOihQvc1ScFQQsUvgnafBVrFmuHq8DlIvj57rq1PVRlJ05g1Kb" ["eVb_visitedfid"]=> string(1) "2" }(可能有不一樣的地方,不用著急)
我們這里注意一下eVb_auth,其實我們的加密信息被存儲到這個COOKIE里了,這里的EVB是DISCUZ默認的COOKIE前綴,如果你更改了COOIKE的話這個也會變化。
所以我們就要處理這個eVb_auth;
function is_login()
{
if(isset($_COOKIE['eVb_auth'])){
list($discuz_pw, $discuz_secques, $discuz_uid) = isset($_COOKIE['eVb_auth']) ? explode("\t", authcode($_COOKIE['eVb_auth'], 'DECODE','123')) : array('', '', 0);
$discuz_pw = addslashes($discuz_pw);
$discuz_secques = addslashes($discuz_secques);
$discuz_uid = intval($discuz_uid);
// 不存在$_DCOOKIE['auth']的話 就直接清楚COOKIE
if(isset($_COOKIE['eVb_auth']) && !$discuz_uid) {
clearcookies();
}
if($discuz_uid){
$sql = "SELECT `username`,`groupid` FROM `cdb_members` WHERE `uid`='$discuz_uid'";
$rs = $this -> _db -> query($sql);
$row = $this -> _db -> fetch($rs);
$discuz_groupid = $row['groupid'];
$discuz_username = $row['username'];
return $array = array("discuz_uid"=>$discuz_uid,"discuz_groupid" => $discuz_groupid,
"discuz_username" => $discuz_username);
}
}else{
if(isset($_COOKIE['eVb_sid'])){
$sid = $_COOKIE['eVb_sid'];
$sql = "SELECT `uid`,`username`,`groupid` FROM `cdb_sessions` WHERE sid ='$sid'";
$rs = $this -> _db -> query($sql);
$row = $this -> _db -> fetch($rs);
if($row){
$discuz_groupid = $row['groupid'];
$discuz_username = $row['username'];
$discuz_uid = $row['uid'];
return $array = array("discuz_uid"=>$discuz_uid,"discuz_groupid" => $discuz_groupid,
"discuz_username" => $discuz_username);
}else{
return 0;
}
}else{
return 0;
}
}
}
我們先看if(isset($_COOKIE['eVb_sid'])){前的這部分
個人感覺唯一要解釋一下的就是這句:list($discuz_pw, $discuz_secques, $discuz_uid) = isset($_COOKIE['eVb_auth']) ? explode("\t", authcode($_COOKIE['eVb_auth'], 'DECODE','123')) : array('', '', 0);
這是將EVB_AUTH解密的過程,這里用DECODE來解密,記得后面的123是你的KEY,要保持一直,不然解密不會成功的。
然后在看下半部分:
DISCUZ是通過SESSION和COOKIE兩種方式加密的,而他的SESSION保存在數(shù)據(jù)庫中,我們下邊這部分就是利用當沒有$_COOKIE['eVb_auth']時,用$_COOKIE['eVb_sid']來取出信息;這不過是個數(shù)據(jù)庫操作,沒啥好將的,這樣,通過建立和讀取我們就可以取出DISCUZ的信息了。
相關文章
Thinkphp 5.0實現(xiàn)微信企業(yè)付款到零錢
這篇文章主要為大家詳細介紹了Thinkphp 5.0實現(xiàn)微信企業(yè)付款到零錢,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-09-09PHP錯誤Allowed memory size of 67108864 bytes exhausted的3種解決辦法
這篇文章主要介紹了PHP錯誤Allowed memory size of 67108864 bytes exhausted的3種解決辦法,PHP的內(nèi)存溢出錯誤,需要的朋友可以參考下2014-07-07php下實現(xiàn)偽 url 的超簡單方法[轉(zhuǎn)]
php下實現(xiàn)偽 url 的超簡單方法[轉(zhuǎn)]...2007-09-09深入解析Laravel5.5中的包自動發(fā)現(xiàn)Package Auto Discovery
眾所周知Laravel 5.5 發(fā)布在即,目前已經(jīng)確定會增加一個神奇的新特性:Package Auto Discovery。下面這篇文章主要給大家深入的介紹了關于Laravel5.5中包自動發(fā)現(xiàn)Package Auto Discovery的相關資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-09-09php實現(xiàn)JWT(json web token)鑒權(quán)實例詳解
這篇文章主要介紹了php實現(xiàn)JWT(json web token)鑒權(quán)實例詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-11-11