ASP個人網站與動網整合非官方方法_應用技巧

來源:互聯網
上載者:User
雖然動網已提供有詳細的"動網論壇系統Api介面開發人員指南",但像我這樣的菜鳥一時半會可是參詳不透的,汗。不甘心,在對其登入、驗證等函數進行一番研究再加以測試後最終竟也小有所成,菜鳥也有菜鳥的辦法: 

本次測試的論壇版本為Version 7.1.0 Sp1,未對其他版本做進行測試 

一、網站檔案結構 

wwwroot 
  ┝ index.asp 
  ┝ CheckUserLogin.asp 
  ┕ bbs/ 

二、整合原理 

對於同步更新實現不困難,整合主要問題就是難在同步登入,所以我們的重點都將放在討論如何?同步登入上。我的方法是將主站使用者表整合至動網使用者表Dv_User中(免去以後得更新兩個庫的麻煩),可按需要在Dv_User新增欄位,並對bbs/login.asp和bbs/inc/Dv_ClsMain.asp做適當的修改;登入時將表單發至bbs/login.asp進行驗證;主站根據動網登入成功後在Session記錄的資訊判斷是否登入成功,並取得使用者資料。 

三、新增修改檔案 

1.index.asp code: 

<html> 
<head> 
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" /> 
<title>個人網站與動網整合(www.mzwu.com)</title> 
</head> 

<body> 
<!--#include file="CheckUserLogin.asp" --> 
<% 
If CheckUserLogin Then 
    Response.write("<a href=""bbs/logout.asp?back=1"">退出登陸</a><p></p>") 
    Response.write("使用者名稱:" & Request.Cookies("username") & "<br>") 
    Response.write("性別:" & Request.Cookies("sex") & "<br>") 
    Response.write("註冊時間:" & Request.Cookies("joindate") & "<br>") 
    Response.write("最後登入:" & Request.Cookies("lastlogin") & "<br>") 
    Response.write("登入次數:" & Request.Cookies("userlogins") & "<br>") 
    Response.write("瀏覽器類型:" & Request.Cookies("browser") & "<br>") 
    Response.write("瀏覽器版本:" & Request.Cookies("version") & "<br>") 
    Response.write("作業系統:" & Request.Cookies("platform") & "<br>") 
Else 
%> 
<form id="form1" name="form1" method="post" action="bbs/login.asp?action=chk&back=1"> 
  使用者名稱: 
    <input name="username" type="text" id="username" size="10" /> 
    <br /> 
    密  碼: 
    <input name="password" type="password" id="password" size="10" /> 
    <input type="submit" name="Submit" value="登入" /> 
</form> 
<% 
End if 
%> 
<p></p><a href="bbs/">進入論壇</a> 
</body> 
</html> 



2.CheckUserLogin.asp code: 

<!--#Include File="bbs/inc/Dv_ClsMain.asp"--> 
<% 
Function CheckUserLogin() 
    Dim Dvbbs,UserSession 
    Const MsxmlVersion=".3.0" 
    Set Dvbbs = New Cls_Forum 
    Set UserSession=Server.CreateObject("msxml2.FreeThreadedDOMDocument"& MsxmlVersion) 
    If UserSession.loadxml(Session(Dvbbs.CacheName & "UserID")&"") Then 
        If UserSession.documentElement.selectSingleNode("userinfo/@userid").text<>"0" Then 
            '在論壇登入成功 
            CheckUserLogin = True 
            '下邊是使用者一些資訊的擷取方法,可自行將其儲存於Cookies或Session中便於使用: 
            '使用者ID      :  UserSession.documentElement.selectSingleNode("userinfo/@userid").text 
            '使用者名稱      :  UserSession.documentElement.selectSingleNode("userinfo/@username").text 
            '生日        :  UserSession.documentElement.selectSingleNode("userinfo/@userbirthday").text 
            '電子郵箱    :  UserSession.documentElement.selectSingleNode("userinfo/@useremail").text 
            '性別        :  UserSession.documentElement.selectSingleNode("userinfo/@usersex").text  '0為女,1為男 
            '註冊時間    :  UserSession.documentElement.selectSingleNode("userinfo/@joindate").text 
            '最後登入    :  UserSession.documentElement.selectSingleNode("userinfo/@lastlogin").text 
            '登入次數    :  UserSession.documentElement.selectSingleNode("userinfo/@userlogins").text 
            '金錢        :  UserSession.documentElement.selectSingleNode("userinfo/@userwealth").text 
            '積分        :  UserSession.documentElement.selectSingleNode("userinfo/@userep").text 
            '魅力        :  UserSession.documentElement.selectSingleNode("userinfo/@usercp").text 
            '最後登入IP  :  UserSession.documentElement.selectSingleNode("userinfo/@userlastip").text 
            '瀏覽器類型  :  UserSession.documentElement.selectSingleNode("agent/@browser").text 
            '瀏覽器版本  :  UserSession.documentElement.selectSingleNode("agent/@version").text 
            '作業系統    :  UserSession.documentElement.selectSingleNode("agent/@platform").text 
            '來訪IP      :  UserSession.documentElement.selectSingleNode("agent/@ip").text 
            '舉例應用: 
            Response.Cookies("username") = UserSession.documentElement.selectSingleNode("userinfo/@username").text 
            Response.Cookies("joindate") = UserSession.documentElement.selectSingleNode("userinfo/@joindate").text 
            If UserSession.documentElement.selectSingleNode("userinfo/@usersex").text="0" Then 
                Response.Cookies("sex") = "靚妹" 
            Else 
                Response.Cookies("sex") = "酷哥" 
            End if 
            Response.Cookies("lastlogin") = UserSession.documentElement.selectSingleNode("userinfo/@lastlogin").text 
            Response.Cookies("userlogins") = UserSession.documentElement.selectSingleNode("userinfo/@userlogins").text 
            Response.Cookies("browser") = UserSession.documentElement.selectSingleNode("agent/@browser").text 
            Response.Cookies("version") = UserSession.documentElement.selectSingleNode("agent/@version").text 
            Response.Cookies("platform") = UserSession.documentElement.selectSingleNode("agent/@platform").text 
        Else 
            '訪問過論壇尚未登入,為來賓狀態 
            CheckUserLogin = False 
        End if 
    Else 
        '未訪問過論壇 
        CheckUserLogin = False 
    End if 
    Set UserSession = nothing 
    Set Dvbbs = nothing 
End Function 
%> 



3.bbs/login.asp新增紅色部分,使在網站首頁登入成功後仍能返回首頁: 

    Dim comeurlname 
    If instr(lcase(request("comeurl")),"reg.asp")>0 or instr(lcase(request("comeurl")),"login.asp")>0 or trim(request("comeurl"))="" Then 
        comeurlname="" 
        comeurl="index.asp" 
    Else 
        comeurl=request("comeurl") 
        comeurlname="<li><a href="&request("comeurl")&">"&request("comeurl")&"</a></li>" 
    End If 

    If request("back")="1" Then 
        Response.Redirect("../index.asp") 
    End If 

    Dim TempStr 
    TempStr = template.html(2) 
    'If Dvbbs.Forum_ChanSetting(0)=1 And Dvbbs.Forum_ChanSetting(10)=1 And Dvbbs.Forum_ChanSetting(12)=1 Then 
    '    TempStr = Replace(TempStr,"{$ray_logininfo}",template.html(3)) 
    'Else 
    '    TempStr = Replace(TempStr,"{$ray_logininfo}","") 
    'End If 
    '----------------------------------------------------------------- 
    '系統整合 
    '----------------------------------------------------------------- 
    If DvApi_Enable Then 
        Response.Write DvApi_SaveCookie 
        Response.Flush 
    End If 
    '----------------------------------------------------------------- 
    TempStr = Replace(TempStr,"{$ray_logininfo}","") 
    TempStr = Replace(TempStr,"{$comeurl}",comeurl) 
    TempStr = Replace(TempStr,"{$comeurlinfo}",comeurlname) 
    TempStr = Replace(TempStr,"{$forumname}",Dvbbs.Forum_Info(0)) 
    Response.Write TempStr 
    TempStr="" 
End Function 



4.bbs/logout.asp新增紅色部分,使在網站首頁點退出登入後仍能返回首頁: 

    '----------------------------------------------------------------- 
    '系統整合 
    '----------------------------------------------------------------- 
    Dim DvApi_Obj,DvApi_SaveCookie,SysKey 
    If DvApi_Enable Then 
        Md5OLD = 1 
        SysKey = Md5(Dvbbs.MemberName&DvApi_SysKey,16) 
        Md5OLD = 0 
        Set DvApi_Obj = New DvApi 
            DvApi_SaveCookie = DvApi_Obj.SetCookie(SysKey,Dvbbs.MemberName,"","") 
        Set DvApi_Obj = Nothing 
        Response.Write DvApi_SaveCookie 
        Response.Flush 
    End If 

    If request("back")="1" Then 
        Response.Redirect("../index.asp") 
    End If 

    '----------------------------------------------------------------- 
    'Response.Redirect Dvbbs.Forum_Info(11) 
    response.write"<script language=JavaScript>" 
    response.write"setTimeout(""window.location='"&Dvbbs.Forum_Info(11)&"'"",1000);" 
    response.write"</script>" 


四、動網設定:去掉登入驗證碼,OK,整合完畢。 

五、擴充: 

預設Dv_User表中的欄位有些時候並不能滿足我們的實際需求,我們就需要新增欄位對其進行擴充,動手吧: 
1.開啟Dv_User表新增一文本類型欄位info_1 
2.bbs/login.asp的ChkUserLogin函數中 
Sql="Select UserID,UserName,UserPassword,UserEmail,UserPost,UserTopic,UserSex,UserFace,UserWidth,UserHeight,JoinDate,LastLogin,lastlogin as cometime , LastLogin as activetime,UserLogins,Lockuser,Userclass,UserGroupID,UserGroup,userWealth,userEP,userCP,UserPower,UserBirthday,UserLastIP,UserDel,UserIsBest,UserHidden,UserMsg,IsChallenge,UserMobile,TitlePic,UserTitle,TruePassWord,UserToday,UserMoney,UserTicket,FollowMsgID,Vip_StarTime,Vip_EndTime,userid as boardid" 
修改為: 
Sql="Select UserID,UserName,UserPassword,UserEmail,UserPost,UserTopic,UserSex,UserFace,UserWidth,UserHeight,JoinDate,LastLogin,lastlogin as cometime , LastLogin as activetime,UserLogins,Lockuser,Userclass,UserGroupID,UserGroup,userWealth,userEP,userCP,UserPower,UserBirthday,UserLastIP,UserDel,UserIsBest,UserHidden,UserMsg,IsChallenge,UserMobile,TitlePic,UserTitle,TruePassWord,UserToday,UserMoney,UserTicket,FollowMsgID,Vip_StarTime,Vip_EndTime,userid as boardid,info_1" 
3.bbs/inc/Dv_ClsMain.asp的TrueCheckUserLogin函數中 
Sql="Select UserID,UserName,UserPassword,UserEmail,UserPost,UserTopic,UserSex,UserFace,UserWidth,UserHeight,JoinDate,LastLogin as cometime ,LastLogin,LastLogin as activetime,UserLogins,Lockuser,Userclass,UserGroupID,UserGroup,userWealth,userEP,userCP,UserPower,UserBirthday,UserLastIP,UserDel,UserIsBest,UserHidden,UserMsg,IsChallenge,UserMobile,TitlePic,UserTitle,TruePassWord,UserToday,UserMoney,UserTicket,FollowMsgID,Vip_StarTime,Vip_EndTime,userid as boardid" 
修改為: 
Sql="Select UserID,UserName,UserPassword,UserEmail,UserPost,UserTopic,UserSex,UserFace,UserWidth,UserHeight,JoinDate,LastLogin as cometime ,LastLogin,LastLogin as activetime,UserLogins,Lockuser,Userclass,UserGroupID,UserGroup,userWealth,userEP,userCP,UserPower,UserBirthday,UserLastIP,UserDel,UserIsBest,UserHidden,UserMsg,IsChallenge,UserMobile,TitlePic,UserTitle,TruePassWord,UserToday,UserMoney,UserTicket,FollowMsgID,Vip_StarTime,Vip_EndTime,userid as boardid,info_1" 
4.CheckUserLogin.asp中 
Response.Cookies("platform") = UserSession.documentElement.selectSingleNode("agent/@platform").text 
後添加 
Response.Cookies("info_1") = UserSession.documentElement.selectSingleNode("userinfo/@info_1").text 
5.index.asp中 
Response.write("作業系統:" & Request.Cookies("platform") & "<br>") 
後添加 
Response.write("新增:" & Request.Cookies("info_1") & "<br>") 
6.OK,圓滿完成 
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.