Passport 通行證 整合第一篇:整合原理

請注意: 整合不成功 " /> 国产成人精品综合在线,97在线精品视频,国产成人精品男人免费

天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

discuz Passport 通行證 整合筆記

太簡單了,但時間長了,記不得,浪費我半小時找資料,深刻體會好記性不如爛筆頭!!今天把passport文擋貼上,防止以后忘記!!記住,網上找到自己需要的資料也要耗時間的!!!!!!


Passport 通行證 整合

第一篇:整合原理

請注意: 整合不成功可能造成的后果-----dz論壇無法登錄,無法管理
解決辦法:
第一步: 到dz的數據庫表cdb_settings 找到下面這幾行修改為
NET attachments month_0609 setting_VJmAq4ZAlhYa.gif?)? ?attach_77703?, event)?> setting.gif (4.3 KB)
2006-9-30 13:59
第二步: 刪除dz安裝目錄/forumdata/cache/cache_settings.php
第三步: 重新訪問論壇


登陸和注冊整合流程
用戶從登陸或注冊表單提交帳號密碼信息 ==>
主站程序檢驗用戶登陸或注冊,成功(注冊需要生成新用戶)則 ==>
設置主站自身的cookie或session    ==>
url傳遞 返回地址forward和編碼后的用戶信息和其他信息 到dz/api/passport.php

整合之前請先仔細閱讀官方passport技術文檔: http://www.discuz.NET/usersguide/advanced_passport.htm 復制內容到剪貼板
代碼:
<?php
//該文檔保存為login.php
//首先將接口技術文檔里的加密解密函數拷貝
//為了不讓代碼太亂,我拷貝到文檔的結尾處
//假設自己的用戶數據庫表里用戶名字段為UserName, 密碼字段為Pwd, Email字段為 Email
//注冊頁實現方法差不多,可自行實現,疑問加我QQ:2666556

$act=(isset($_GET['act']))?$_GET['act']:"login";
if(function_exists($act)) $act();else login();        

function login()
{        
        $ErrMsg=UserCheck();
        if($ErrMsg!="")echo $ErrMsg;        
        //后面加上顯示你的登陸表單的代碼 如
?>
<form action=login.php?act=login method=post>
用戶名:<input name=username>
密碼:<input name=password>
<input name=submit type=submit value=登陸></form>
<?php

}//end function

function logout()//登出
{
        $passportkey="1234567890";//這里換成你論壇通行證設置的passportkey
        $auth=$_COOKIE['auth'];
        setcookie("auth", "",time() - 3600);
        $forward=$_GET['forward'];
        if($forward=="")$forward="../../index.php";//這里換成你的主頁絕對地址或相對地址                                       
        $verify = md5('logout'.$auth.$forward.$passportkey);
        $auth=rawurlencode($auth);
        $forward=rawurlencode($forward);
        header("Location: bbs/api/passport.php?action=logout&auth=$auth&forward=$forward&verify=$verify");
}

function UserCheck()
{        
        $passportkey="1234567890";//這里換成你論壇通行證設置的passportkey

        //===========驗證輸入=====================
        if(!isset($_POST['submit'])) return; // login表單的按鈕需要與此同名
        $usnm=$_POST['username'];//username換成你登陸表單里的用戶名域                        
        $pwd=$_POST['password'];//password換成你登陸表單里的密碼域                        
        if($usnm=="") return "請輸入用戶名!";
        if($pwd=="") return "請輸入密碼!";

        //=========數據庫處理==========================
        $db=mysql_connect("localhost", "root", "");
        mysql_select_db("your_db_name");
$sql="Select * from `user` where UserName='".$usnm."' Limit 1";        
        $rs = mysql_query($sql,$db)        ;
        $row = mysql_fetch_array($rs);
        if(!$row)return "該用戶不存在";
        if($row["Pwd"]!=md5($pwd))return "密碼錯誤";
        mysql_free_result($rs);        

        //==============header到bbs=====================        
        $member = array
        (
                        'time'     => time(),
                        'username' => $row["UserName"],
                        'password' => $row["Pwd"],
                        'email'    => $row["Email"]
        );
        $auth = passport_encrypt(passport_encode($member), $passportkey);
        setcookie("auth",$auth,($_POST["Cookie"]? time()+(int)$_POST["Cookie"] :0));
        $forward=$_POST['forward'];
        if($forward=="")$forward="../../index.php";                                       
        $verify = md5('login'.$auth.$forward.$passportkey);
        $auth=rawurlencode($auth);
        $forward=rawurlencode($forward);
        header("Location: bbs/api/passport.php?action=login&auth=$auth&forward=$forward&verify=$verify");                        

}


//=============================================================
//=============以下為拷貝過來的函數============================
function passport_encrypt($txt, $key) {
        srand((double)microtime() * 1000000);
        $encrypt_key = md5(rand(0, 32000));        
        $ctr = 0;
        $tmp = '';
        for($i = 0; $i < strlen($txt); $i++) {
                        $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
                        $tmp .= $encrypt_key[$ctr].($txt[$i] ^ $encrypt_key[$ctr++]);
        }
        return base64_encode(passport_key($tmp, $key));
}

function passport_decrypt($txt, $key) {
        $txt = passport_key(base64_decode($txt), $key);
        $tmp = '';
        for ($i = 0; $i < strlen($txt); $i++) {
                 $tmp .= $txt[$i] ^ $txt[++$i];
        }
        return $tmp;
}

function passport_key($txt, $encrypt_key) {
        $encrypt_key = md5($encrypt_key);
        $ctr = 0;
        $tmp = '';
        for($i = 0; $i < strlen($txt); $i++) {
                        $ctr = $ctr == strlen($encrypt_key) ? 0 : $ctr;
                        $tmp .= $txt[$i] ^ $encrypt_key[$ctr++];
        }
        return $tmp;
}

function passport_encode($array) {
        $arrayenc = array();
        foreach($array as $key => $val) {
                   $arrayenc[] = $key.'='.urlencode($val);
        }
        return implode('&', $arrayenc);

}
//=========================================================================
//===========================拷貝結束======================================
?>

php技術discuz Passport 通行證 整合筆記,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产爱豆果冻传媒在线观看视频 | chinese情侣自拍啪hd | 大香网伊人久久综合网2020 | 东莞桑拿美女 | 欧美日韩精品久久久免费观看 | 免费精品美女久久久久久久久 | 亚洲中文字幕一二三四区苍井空 | 小箩莉奶水四溅小说 | 伊人亚洲综合青草青草久热 | 久久国产精品免费A片蜜芽 久久国产精品萌白酱免费 久久国产精品麻豆AV影视 | 5G年龄确认我已满18免费 | 亚洲 欧美 日韩 卡通 另类 | china年轻小帅脸直播飞机 | 国产爱豆果冻传媒在线观看 | 伊人久久久久久久久久 | 国产AV精品无码免费看 | 涩涩视频www在线观看入口 | 久久久无码精品亚洲欧美 | 欧美一区二区日韩一区二区 | 国产色青青视频在线观看 | 国产福利视频在线观看福利 | 浴室里强摁做开腿呻吟的漫画 | 国产麻豆剧看黄在线观看 | 国产AV白丝爆浆在线播放 | 夜夜骑夜夜欢 | 国产在线视频一区二区不卡 | 99久久国产露脸精品国产麻豆 | 99精品中文字幕在线观看 | 国产亚洲精品久久综合阿香 | 秋霞网在线伦理影片 | 日本漂亮妈妈7观整有限中 日本片bbbxxx | 亚洲色偷偷偷网站色偷一区人人藻 | 亚洲三级黄色片 | 国产精品久久久久久人妻精品流 | 国产成人永久免费视频 | 伊人久久大香线蕉avapp下载 | 你的欲梦裸身在线播放 | 黄色小说在线 | 久久亚洲视频 | 一边啪啪的一边呻吟声口述 | WWW国产精品内射老师 |