BrnShop开源网上商城第一讲:架构设计

原文: BrnShop开源网上商城第一讲:架构设计

  首先在此感谢你们对BrnShop项目的支持和鼓励!咱们在发布BrnShop之前曾推测项目会受到很多园友的支持,但没想到园友们的支持大大超过咱们的预测。4天6000次浏览,140个推荐,170个评论,8000次下载。看到这些数据后咱们心里除了激动外,更多了一份责任。不管未来遇到多大的困难,咱们必定要坚持把BrnShop坚持到底!!html

  若是你还不知道BrnShop是什么或尚未下载源码的能够点此下载,若是下载源码后发现商城有bug,也能够点此下载(什么?你仍是1.0.**版本?咱们如今都已经更新到1.0.141版本了!)。web

  在开始今天的主题前,有个问题先向你们解释下:很多园友运行咱们的程序后,觉得前台页面功能不完整,因而认为咱们的商城是个残缺品,功能不全。在此我针对这个问题向你们郑重说明下:不是咱们的功能不全,对于一个商城来讲该有的功能咱们程序都提供了,不信你能够查看下每一个控制器及它的动做方法,就会发现你想要的各个功能。只是这些功能默认主题并无相应的页面或糅合进别的页面去了。咱们的默认主题只提供一个演示功能(君没见Php的ecshop的默认主题更粗糙吗?)。sql

  好了,下面进入今天的主题:BrnShop开源网上商城架构设计缓存

  拿到源码的朋友知道BrnShop解决方案是由4个解决方案文件夹构成的。它们分别是Libraries,Presentation,Strategies和Plugins,下面是这四个解决方案文件夹的截图和介绍:架构

  

  • Libraries:商城基础类库,主要提供系统核心,数据访问,业务逻辑等功能。
  • Presentation:商城web展现,提供网站前台和后台实现。
  • Strategies:包含各类策略程序集
  • Plugins:包含开发受权,支付等插件。

  经过上面的介绍你们能够看出其实BrnShop的主要功能都在Libraries和Presentation中,而Strategies和Plugins只是提供程序外围的一些服务。到这相信你们的思路就清晰多了,下面依次介绍各个项目:mvc

  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\”post

  目前商城默认实现了每一个策略,他们的对应关系及介绍以下:网站

  

  • 当前只有企业版提供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策略程序集。url

  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实现。敬请期待!

  有对网上商城程序设计感兴趣的朋友,欢迎加入QQ群:235274151,你们能够探讨下!

相关文章
相关标签/搜索