petshop4.0 各个文件的作用

petshop4.0设计说明 (转) 一、项目名称及描述:(实现步骤为:4-3-6-5-2-1)

1、WEB=表示层

2、BLL=业务逻辑层

3、IDAL=数据访问层接口定义

4、Model=业务实体

5、DALFactory=数据层的抽象工厂(创建反射)

6、SQLServerDAL=SQLServer数据访问层 / OracleDAL=Oracle数据访问层

DBUtility 数据库访问组件基础类

二、项目引用关系

1、Web 引用 BLL。

2、BLL 引用 IDAL,Model,使用DALFactory创建实例。

3、IDAL 引用 Model。

4、Model 无引用。

5、DALFactory 引用IDAL,通过读取web.config里设置的程序集,加载类的实例,返回给BLL使用。

6、SQLServerDAL 引用 Model和IDAL,被DALFactory加载的程序集,实现接口里的方法。

三、实现步骤

1、创建Model,实现业务实体。

2、创建IDAL,实现接口。

3、创建SQLServerDAL,实现接口里的方法。

4、增加web.config里的配置信息,为SQLServerDAL的程序集。

5、创建DALFactory,返回程序集的指定类的实例。

6、创建BLL,调用DALFactory,得到程序集指定类的实例,完成数据操作方法。

7、创建WEB,调用BLL里的数据操作方法。

注意:

1、web.config里的程序集名称必须与SQLServerDAL里的输出程序集名称一致。

2、DALFactory里只需要一个DataAccess类,可以完成创建所有的程序集实例。

3、项目创建后,注意修改各项目的默认命名空间和程序集名称。

4、注意修改解决方案里的项目依赖。

5、注意在解决方案里增加各项目引用。

1

WEB

     表示层

2

Model

PetShop.Model PetShop.Model 业务实体

3

BLL

PetShop.BLL PetShop.BLL 业务逻辑层

4

DALFactory

PetShop.DAL PetShop.DALFactory 数据层的抽象工厂

5

IDAL

PetShop.IDAL PetShop.IDAL 数据访问层接口定义

6

SQLServerDAL

PetShop.SQLServerDAL PetShop.SQLServerDAL SQLServer数据访问层

7

OracleDAL

PetShop.OracleDAL PetShop.OracleDAL Oracle数据访问层

8

DBUtility

PetShop.DBUtility PetShop.DBUtility 数据库访问组件基础类

9

CacheDependencyFactory

PetShop.CacheDependencyFactory PetShop.CacheDependencyFactory 缓存依赖类的工厂类

10

ICacheDependency

PetShop.ICacheDependency PetShop.ICacheDependency 缓存依赖类接口

11

TableCacheDependency

PetShop.TableCacheDependency PetShop.TableCacheDependency 缓存依赖实现类

12

IBLLStrategy

PetShop.IBLLStrategy PetShop.IBLLStrategy 同步/异步处理策略接口(实现在bll根据配置反射选择)

13

MessagingFactory

PetShop.MessagingFactory PetShop.MessagingFactory 异时处理消息队列的抽象工厂

14

IMessaging

PetShop.IMessaging PetShop.IMessaging 异时处理消息队列接口定义

15

MSMQMessaging

PetShop.MsmqMessaging PetShop.MsmqMessaging 异时处理消息队列的实现

16

Profile

PetShop.Profile PetShop.Profile Profile的数据访问层

17

ProfileDALFactory

PetShop.ProfileDALFactory PetShop.ProfileDALFactory ProfileDAL的工厂类(反射创建ProfileDAL)

18

IProfileDAL

PetShop.IProfileDAL PetShop.IProfileDAL Profile的数据访问层接口定义

19

OracleProfileDAL

PetShop.OracleProfileDAL PetShop.OracleProfileDAL Oracle的Profile Providers

做用户状态管理

20

SQLProfileDAL

PetShop.SQLProfileDAL PetShop.SQLProfileDAL SQL Server 的Profile Providers

做用户状态管理

21

Membership

PetShop.Membership PetShop.Membership Membership认证和授权管理

22

OrderProcessor

PetShop.OrderProcessor PetShop.OrderProcessor 后台处理进程,处理订单队列

些项目可以分类来理解,主要包括以下几个部分,

Web ??        ??外观层

Bill ?                    ?业务逻辑层

IDAL?                ? 数据访问层接口

DALFactory?       ? 数据层的抽象工厂

SQLServerDAL     ?SQL数据访问层

OracleDAL                Oracle数据访问层

Model                         业务实体层

DBUtility                    数据访问组件基础类

CacheDependencyFactory 缓存依赖的工厂类

ICacheDependency           缓存依赖类接口

TableCacheDependency   缓存依赖实现类

IBLLStrategy                      同步/异步处理策略接口

MessagingFactory               异时处理消息队列的抽象工厂

IMessaging                            异时处理消息队列接口定义

MSMQMessaging                    异时消息队列的实现

Profile                                          Profile数据访问层

ProfileDALFactory                      ProfileDAL的工厂类

IProfileDAL                                Profile数据访问层接口定义

OracleProfileDAL?????Oracle的Profile Providers 做用户状态管理

SQLProfileDAL?????SQL Server 的Profile Providers 做用户状态管理

Membership??????Membership认证和授权管理

OrderProcessor????后台处理进程,处理订单队列

SQL数据库中含有四个数据库

它们分别为:MSPetShop4 ,MSPetShop4Oreder,  MSPetShop4Profile 和MSPetShop4Servers

其中MSPetShop4有如下几个表?分别为CateGory  Product Item Supplier和Inventory五个表

其中CateGory存储宠物类别有关信息?Product存储宠物的商品目录?Item存储宠物的详细信息

Supplier存储相关供应商的信息?Inventory存储和每种宠物的具体数量

MSPetShop4Order 含有一下三个表?其数据库模型如下

petshop4.0 各个文件的作用 - 贵霜楼沙 - 葵花即将盛开

Order表存储了订单的详细通信信息??OrderStatus记录了订单的状态??LineItem记录了订单中的宠物数量等等详细信息

MSPetshopPrifile 的数据库模型如下

petshop4.0 各个文件的作用 - 贵霜楼沙 - 葵花即将盛开

其中Profile表记录了客户的基本活动信息

Account 记录了客户的身份地址相关信息

Cart记录了用户的意向清单和购物列表

最后一个数据库就是MSPetShop4Servers??它相当于Visual Studio内置的成员和角色管理的数据库

这里不在讨论

在这么简单的功能中建如此大的工程和复杂的数据库设计.微软肯定有自己的卖点

下面我们看看PetShop4.0中相对于3.0的新增相关技术!

 

?

 

用 System.Transactions 代替服务组件。

 

?

 

用强类型集合的泛型代替松散类型的 ILists。

 

?

 

ASP.NET 2.0 成员身份,用于用户身份验证和授权。

 

?

 

用于 Oracle 10G 的自定义 ASP.NET 2.0 成员身份提供程序。

 

?

 

ASP.NET 2.0 自定义 Oracle 和 SQL Server 配置文件提供程序,用于用户状态管理。

 

?

 

用母版页取代 ASP.NET Web 用户控件,从而获得一致的外观。

 

?

 

ASP.NET 2.0 向导控件。

 

?

 

使用 SqlCacheDependency(而非基于超时)的数据库级缓存失效。

 

?

 

启用基于消息队列构建的异步 Order 处理

 

 

在这个工程中用到了抽象工厂设计模式?

我对设计模式了解的很少,明天深入学习一下抽象工厂设计模式,同时试着做一个类似多层的项目以尽快熟悉2005和了解它的新特性?

所谓“依懒注入”

就是将应用程序所依赖的组件在运行时动态的加载到应用

程序中。依赖注入的目标并非为应用程序添加更多的功能,而是提升了组件的

重用性,并为应用程序搭建一个具有较强灵活性和扩展性的平台。在程序实现上就用

Assembly.Load(AssemblyName).CreateInstance(typeName)在程序运行时动态创建实例.PetShop4.0中多次应用了与配置文件相强合的反射注入技术。下面就介绍一下反射注入技术在PetShop4.0多层应用程序和应用。

 

 

项目名

 

 

PetShop.CacheDependencyFactory

 

 

类名

 

 

DependencyAccess

 

 

方法

 

 

privatestaticIPetShopCacheDependency LoadInstance(string className)

 

 

配置文件中的值

 

 

<appSetting>

……….

<add key="CacheDependencyAssembly" value="PetShop.TableCacheDependency"/>

……

</appSetting>

 

 

代码文件中的实现

 

 

string path=ConfigurationManager.AppSettings["CacheDependencyAssembly"];

string fullyQualifiedClass = path + "." + className;

return (IPetShopCacheDependency)Assembly.Load(path)

.CreateInstance(fullyQualifiedClass);

 

 

从上面的实现来看其实是很简单的。三个步骤就实现了:两前个步骤,主要是为动态创建

实例提供参数:程序集名称,和类名称(类型名).

1.    执行ConfigurationManager.AppSettings[“keyName”]来获取配置文件中的键值,也就

程序集的名称AssemblyName。

2.    组合类名称typeName。

3.    执行Assembly.Load(AssemblyName).CreateInstance(typeName)进行动太创建实例

其实PetShop4.0中实现反射注入技术都是上面的那种思想。所以下面就省去配置文件中的

信息和实现的代码实现信息,只是统计反射注入技术在PetShop4.0中应用的位置信息。

 

 

 

 

项目名

 

 

PetShop.DALFactory

 

 

类名

 

 

DataAccess

 

 

方法

 

 

1.    public static PetShop.IDAL.ICategory CreateCategory()

2.       public static PetShop.IDAL.IInventory CreateInventory()

3.       public static PetShop.IDAL.IItem CreateItem()

4.       public static PetShop.IDAL.IOrder CreateOrder()

5.       public static PetShop.IDAL.IProduct CreateProduct()

 

 

 

 

项目名

 

 

PetShop.MessagingFactory

 

 

类名

 

 

QueueAccess

 

 

方法

 

 

public static PetShop.IMessaging.IOrder CreateOrder()

 

 

  

 

项目名

 

 

PetShop.ProfileDALFactory

 

 

类名

 

 

DataAccess

 

 

方法

 

 

Publics  tatic

PetShop.IProfileDAL.IPetShopProfileProvider

CreatePetShopProfileProvider()

posted on 2012-07-31 14:54  竹影青瞳  阅读(319)  评论(0编辑  收藏  举报