程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> 關於PHP編程 >> 關於DISCUZ不用通行證登陸得內容介紹第1/2頁

關於DISCUZ不用通行證登陸得內容介紹第1/2頁

編輯:關於PHP編程

關於DISCUZ不用通行證登陸得內容介紹
DISCUZ是中國最常用的論壇,雖然他本身有通行證給大家連接,但實際上用戶的統一還是很不好,經常要建立兩個用戶表,第一不利於注冊和管理,第二浪費數據庫。
最近做一個項目也是使用的DISCUZ,所以研究了一下DISCUZ的登陸,基本完成了同步登陸。大家如果有興趣可以研究一下。
別的不廢話了,如果你自己寫的系統,可以直接用DISCUZ的公用文件,直接引用include/common.inc.php就好了,這樣最簡單了,只要引用這個文件,$discuz_uid就是你的用戶ID了,$discuz_user就是你的用戶名,
如果你用的自己的公用文件,就要提取兩個函數,在global.func.php中,有兩個函數
Dsetcookie,和authcode,如果你不懶的話在復制一個函數clearcookies,第一個就是DISCUZ自己的建造COOKIE的函數,第二個是DISCUZ的可逆加密函數,第三個是清除COOKIE函數,我是放到我自己的FUNC.PHP文件中了
好了,咱們開始寫建立和識別COOKIE的方法了
function lgoin($array)
{
$username = $array['username'];
$password = $array['password'];
$sql = "SELECT `uid`,`password`,`secques` FROM `cdb_members` WHERE
`username`='$username' and `password`=md5('$password')";
try {
$rs = $this -> _db -> query($sql);
}catch (Exception $e){
exit("查詢出錯,出錯信息:".$e->getMessage());
return 0;
}
$row = $this -> _db -> fetch($rs); //查詢登陸的用戶名和密碼是否正確
if($row){
dsetcookie('sid','',-2423234234); // 注銷掉sid
$secques = $row['secques'];
$uid = $row['uid'];
$formPassword = $row['password'];
dsetcookie('auth', authcode("$formPassword\t$secques\t$uid", 'ENCODE','123'), '0');
return 1;
}else{
return 2;
}
}

這是一個登陸函數,廢話不說了,直接說關鍵部分吧,在查詢之後,當獲得到信息後,(用戶名和密碼正確的話)我們獲得3個信息,UID,PASSWORD,和SECQUES,這三個是DISCUZ建立COOKIE需要用的,第一個是用戶ID,第二個是加密後的密碼,第三個是加密後的回答問題答案(即使沒有設置也要用),DISCUZ是需要提示問題和答案的,而我們登陸就不需要了,所以我這裡直接把他查出來了。dsetcookie('auth', authcode("$formPassword\t$secques\t$uid", 'ENCODE','123'), '0');
這句就是建立用戶的COOKIE,別的不用說了,請注意這句'123',這個地方一定要注意,這個是加密時設置的KEY,就是你這裡需要和你DISCUZ的一樣,所以有三個地方一定要統一,一個是global.func.php,一個是你自己復制出來的那個authcode函數,還有就是你在使用authcode的時候。這時候論壇應該可以登陸了,如果不能登陸,請看下面

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved