各頻道分別位于不同的web project(具有獨立的二級域名),并將所有的業務邏輯以及數據訪問功能封裝成class library,所有頻道共用這個class library。
下面詳細介紹實現方法。
假設網站有三個頻道,新聞、論壇以及博客,對應的二級域名為"news"、"forum"、"blog"。除此之外,還需要另外定義兩個域名,分別用于網站首頁以及用戶注冊、登陸功能(基于passport機制,本文后面將作詳細介紹),對應域名為"homepage"、"passport"。
1、配置各頻道url
a、配置hosts文件
用文本編輯器打開hosts文件(位于c:/windows或winnt/system32/drivers/etc/),該文件中存放初始的域名解析信息。當我們在瀏覽器中請求某個url時,系統首先在hosts文件中查找相應域名,如果找到則跳轉至指定ip,如果沒找到,則進一步提交dns進行域名解析。
配置很簡單,格式形如"[ip][空格][域名]",每條數據對應一行。下面為配置內容:
192.168.1.2 www.mysite.com
192.168.1.2 passport.mysite.com
192.168.1.3 news.mysite.com
192.168.1.5 forum.mysite.com
192.168.1.9 blog.mysite.com
你可能已經注意到了,各頻道對應于不同的ip,這正是該架構的開發靈活性所在。各頻道(web project)可以創建于不同的開發者電腦。通過將配置內容同步到各臺電腦,可以方便的在各頻道間進行頁面瀏覽,就像這些頻道位于你自己的電腦一樣!采用這種方式可以極大降低開發耦合性,每個頻道都是一個獨立的模塊,一個頻道中的bug不會影響到另一個頻道。
b、配置web.config
考慮到各頻道二級域名有可能進行調整,將相應配置信息存放于web.config文件是一個好辦法。同樣的,該配置信息必須同步到各web project。下面為配置內容:
<add key="sitedomainname" value="mysite.com"/>
<add key="homepagesiteurl" value="http://www.mysite.com/homepage/"/>
<add key="passportsiteurl" value="http://passport.mysite.com/passport/"/>
<add key="newssiteurl" value="http://news.mysite.com/news/"/>
<add key="forumsiteurl" value="http://forum.mysite.com/forum/"/>
<add key="blogsiteurl" value="http://blog.mysite.com/blog/"/>
<add key="localsiteurl" value="/blog/"/>
各配置項說明如下
sitedomainname:站點域名,形如"mysite.com"、"mysite.com.cn"、"mysite.net"等。該配置項的使用方法將在后文介紹。
localsiteurl:當前頻道根路徑,也就是web project所在網站或虛擬目錄的路徑,以"/"開頭。該配置項主要用于頻道內部的引用,比如圖片引用、頁面鏈接等。
其余配置項:用于頻道間的引用,比如頻道導航、功能調用等。
2、創建model部件
在mvc模式組成中,model部件包括所有的業務邏輯操作,其中也包含數據訪問操作。
本方案將model部件拆分成對象實體、對象操作以及數據訪問三部分,封裝成三個class library。
由于class library設計本身就是一個很大的話題,本文就不再祥述了,有興趣的話可以參考一些相關資料。
經驗分享:
上述的model部件拆分方式適用于業務功能比較復雜的大型項目,要求團隊內部有著明確、細化的分工合作。但如?????? ?o??果面對的是中小型項目,該方式很有可能成為開發效率的瓶頸。這主要是由項目特點決定的,中小型項目業務功能相比大型項目沒有那么復雜,開發人員數量也比較有限,往往一個人要負責整個模塊的開發。在這種情況下,架構層次過于繁多,每次修改一個層時,其他相關層也得跟著同步修改,這樣反而影響了開發效率。
3、實現passport機制
很多網站都采用session來存放個人信息,比如登錄信息,并以次作為用戶登錄與否的判斷依據。但session有一個缺陷,就是無法在多個web應用中共享,一個web應用生成的session只能由他自己使用。哪種方法可以在多個web應用中實現數據共享呢?答案是cookie。cookie將信息存放于客戶端, 并在需要時發送回服務器端。
passport,即通行證,是目前普遍采用的一種用戶身份認證機制,簡單來說就是一次登錄,全站通行。這也正是我們的要求。
這里討論的通行證機制基于cookie,實現也比較方便。其中的關鍵點是cookie的domain屬性設置,domain屬性表示cookie信息回發的目標域,也就是接收cookie的域,接收cookie的域必須與發送cookie的域一致,否則無效。比如:發送域為"blog.mysite.com",則接收域可以設為"blog.mysite.com"或"mysite.com",而"news.mysite.com"和"blog.yoursite.com"為無效接收域。要想讓所有頻道都能接收到cookie,必須將domain屬性設置為不帶二級域名前綴的形式,如"mysite.com"、"mysite.com.cn"、"mysite.net"等。
登錄成功后向客戶端發送相應cookie,其中可以包括一些全局信息,比如用戶編號、用戶名等。用戶退出時刪除相應cookie,特別要注意的是,刪除cookie時也要設置正確的domain屬性。
關于該passport機制,還有兩個問題值得討論:
a、cookie的過期時間
有兩種方案可以采用,一種是默認方式,即不設置cookie的expires屬性,采用這種方案時,cookie存放于內存中,在瀏覽器關閉前cookie將一直存在,也就是一直處于登錄狀態。這種方式主要用于對信息安全要求不是很高的網站,比如娛樂休閑類網站;另一種是指定明確的過期時間,一般情況下會將用戶最后一次訪問網站的時間加上一個超時時間段作為過期時間,有點類似于asp中的session超時機制,這種方式主要用于對安全性要求比較高的網站,比如網上銀行、電子郵箱等。
b、cookie的信息安全
由于cookie是以明文方式傳遞數據,不可避免的存在安全隱患,因此對重要數據的加密是非常有必要的。加密可以采用可逆算法,比如des。
4、創建web project
前文已提過,web project的創建比較靈活,既可以創建于不同的開發者電腦,也可以創建于同一臺電腦。這主要取決于開發團隊規模。
5、部署
分別部署各頻道,設置二級域名,將web.config中的相關配置改為生產環境的實際數據。
其中比較繁復的工作就是各頻道中相同部分的部署,比如說網站頭部(logo、導航欄等),網站底部(版權聲明、聯系方式等),圖片,css,javascript等。當然也可以把這些公用資源單獨部署于一個頻道中,以供其他頻道調用,但這樣做就破壞了各頻道松耦合的特性,如果用于存放公用資源的頻道出了問題,那其余頻道也將無法正常使用。
結束
本文討論了asp.net中多頻道網站架構的一種實現方法,由于涉及到的內容較多,無法一一展開,但對其中的重點部分還是多加了點筆墨,希望對你有用。
新聞熱點
疑難解答
圖片精選