BrnShop開源網上商城第一講:架構設計


首先在此感謝大家對BrnShop項目的支持和鼓勵!我們在發布BrnShop以前曾推測項目會受到不少園友的支持,但沒想到園友們的支持大大超過我們的預測。4天6000次瀏覽,140個推薦,170個評論,8000次下載。看到這些數據后我們內心除了激動外,更多了一份責任。無論將來遇到多大的困難,我們一定要堅持把BrnShop堅持到底!!

  如果你還不知道BrnShop是什么或還沒有下載源碼的可以點此下載,如果下載源碼后發現商城有bug,也可以點此下載(什么?你還是1.0.**版本?我們現在都已經更新到1.0.141版本了!)。

  在開始今天的主題前,有個問題先向大家解釋下:不少園友運行我們的程序后,以為前台頁面功能不完整,於是認為我們的商城是個殘缺品,功能不全。在此我針對這個問題向大家鄭重說明下:不是我們的功能不全,對於一個商城來說該有的功能我們程序都提供了,不信你可以查看下每個控制器及它的動作方法,就會發現你想要的各個功能。只是這些功能默認主題並沒有相應的頁面或糅合進別的頁面去了。我們的默認主題只提供一個演示功能(君沒見Php的ecshop的默認主題更粗糙嗎?)。

  好了,下面進入今天的主題:BrnShop開源網上商城架構設計

  拿到源碼的朋友知道BrnShop解決方案是由4個解決方案文件夾構成的。它們分別是Libraries,Presentation,Strategies和Plugins,下面是這四個解決方案文件夾的截圖和介紹:

  

  • Libraries:商城基礎類庫,主要提供系統核心,數據訪問,業務邏輯等功能。
  • Presentation:商城web展示,提供網站前台和后台實現。
  • Strategies:包含各種策略程序集
  • Plugins:包含開發授權,支付等插件。

  通過上面的介紹大家可以看出其實BrnShop的主要功能都在Libraries和Presentation中,而Strategies和Plugins只是提供程序外圍的一些服務。到這相信大家的思路就清晰多了,下面依次介紹各個項目:

  BrnShop.Core項目:這個項目是BrnShop最核心的項目,它提供商城最底層,最基礎的服務。首先通過圖片給出各個模塊的基本介紹:

  

  • 對於異步模塊,緩存模塊,配置模塊,數據模塊,郵箱模塊,隨機值模塊,Session模塊,短信模塊這8個模塊來說,BrnShop.Core項目只提供加載和接口,並不包含具體實現。大家請看郵箱模塊代碼(其它7個模塊的實現原理一樣):
復制代碼
 1     /// <summary>
 2     /// BrnShop郵件管理類
 3     /// </summary>
 4     public class BSPEmail
 5     {
 6         private static IEmailStrategy _emailstrategy = null;//郵件策略
 7 
 8         static BSPEmail()
 9         {
10             Load();
11         }
12 
13         /// <summary>
14         /// 郵件策略實例
15         /// </summary>
16         public static IEmailStrategy Instance
17         {
18             get { return _emailstrategy; }
19         }
20 
21         /// <summary>
22         /// 加載郵件策略
23         /// </summary>
24         private static void Load()
25         {
26             try
27             {
28                 string[] fileNameList = Directory.GetFiles(System.Web.HttpRuntime.BinDirectory, "BrnShop.EmailStrategy.*.dll", SearchOption.TopDirectoryOnly);
29                 _emailstrategy = (IEmailStrategy)Activator.CreateInstance(Type.GetType(string.Format("BrnShop.EmailStrategy.{0}.EmailStrategy, BrnShop.EmailStrategy.{0}", fileNameList[0].Substring(fileNameList[0].IndexOf("EmailStrategy.") + 14).Replace(".dll", "")),
30                                                                                        false,
31                                                                                        true));
32             }
33             catch
34             {
35                 throw new BSPException("創建\"郵件策略對象\"失敗,可能存在的原因:未將\"郵件策略程序集\"添加到bin目錄中;將多個\"郵件策略程序集\"添加到bin目錄中;\"郵件策略程序集\"文件名不符合\"BrnShop.EmailStrategy.{策略名稱}.dll\"格式");
36             }
37         }
38 
39     }
復制代碼

  通過以上代碼大家不難看出實現的核心思想就是“約定大於配置”和“策略模式”。這里的“約定大於配置”大家需要注意下,如果大家想自己實現一個策略,例如郵箱策略(其它策略一樣),請一定要保證符合約定限制,具體就是程序集名一定要滿足“BrnShop.EmailStrategy.{自定義名稱}.dll”格式,命名空間滿足"BrnShop.EmailStrategy.{自定義名稱}"格式,主類名必須是“EmailStrategy”。還有一點就是為了保證策略程序集能正確的編譯到BilShop.Web項目的bin文件夾中,一定要配置項目生成的輸出路徑為“..\..\Presentation\BrnShop.Web\bin\”

  目前商城默認實現了每個策略,他們的對應關系及介紹如下:

  

  • 當前只有企業版提供NOSQL實現,所以目前Data文件夾中的NOSQL為空,后期隨着企業版的開源也會補上NOSQL代碼實現。
  • 插件部分內容比較多,我后面會專門寫一遍博客介紹。不過大家可以先看看這篇文章http://shazwazza.com/post/Developing-a-plugin-framework-in-ASPNET-with-medium-trust

  BrnShop.Data項目:這個項目主要是通過調用BrnShop.Core項目中的BSPData類來和各種數據存儲做交互,大家可以自己看下代碼,都有注釋,沒什么難度。PS:前幾天園子里有個朋友說想用EF替換掉sql語句和存儲過程,他當時的替換點是重寫BrnShop.Data項目,在此我不反對他使用EF,只是替換點不應該是BrnShop.Data項目,而是BrnShop.RDBSStrategy.SqlServer策略程序集。

  BrnShop.Services項目:商城的業務功能實現,如果你想找商城某個功能的實現可以來這個項目中找,例如購物車的實現。PS:在BrnShop.Service項目中有個Admin文件夾,這個文件夾是商城后台操作要用到的類。

  BrnShop.Web.Framework項目:這個項目主要提供商城web層面的設計。大家可以打開看一看里面都是自定義控制器類,分頁,動作篩選器等MVC方面的東西。

  BrnShop.Web.Admin項目:商城網站后台,這個項目的類型是類庫,不是web項目(但mvc的各部分俱全),所以不能直接啟動。PS:關於網站發布問題,這里提供一個簡單的方法,首先將vs的生成配置改成"release",然后將BrnShop.Web項目中的web.config文件中的compilation節點的debug屬性設置成“false”,然后重新生成BrnShop.Web項目,最后把BrnShop.Web項目的文件夾復制並刪除無用的文件(例如obj文件夾下的文件)到iis中就可以了。

  BrnShop.Web項目:商城網站前台:使用ASP.NET MVC3實現。各個文件夾或文件解釋如下:

  

  今天這一篇博文主要是幫助大家對BrnShop項目有個整體的認識,下一篇我會介紹下BrnShop的ASP.NET MVC實現。敬請期待!


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM