MVC项目实践,在三层架构下实现SportsStore,从类图看三层架构

在"MVC项目实践,在三层架构下实现SportsStore-02,DbSession层、BLL层"一文的评论中,博友浪花一朵朵建议用类图来理解本项目的三层架构。于是就有了本篇:

 

  IDAL层

IDAL

 

→IBaseRepository接口,基接口,提供泛型实现

所有的数据接口层的方法基本上是一样的,包括查询、分页查询、添加、批量添加、更新、批量更新、删除、批量删除等。所以,有必要针对所有的数据接口提炼出基接口,提供泛型实现。

 

→IProductRepository接口

实现IBaseRepository接口。

 

→IDbContextFactory接口,当前EF上下文的抽象工厂

在DAL的BaeRepository中一定会用到EF上下文,我们借助IDbContextFactory这个"抽象工厂"生产DbContext的实例。

 

→IDbSession接口,数据库访问层的统一入口接口

主要做了3件事:
1、提交所有变化
2、拿到各个IXXXRepository类型
3、执行SQL语句

 

→IDbSessionFactory接口,IDbSession接口的抽象工厂

在BLL的BaseService中一定会用到IDbSession这个数据层的统一入口,我们借助IDbSessionFactory这个"抽象工厂"生产IDbSession的实例。

 

  DAL层

DAL

 

→BaseRepository,所有XXXRepository的基类,提供泛型实现

BaseRepository没必要实现IBaseRepository,因为它的存在是为了避免各个XXXRepository代码重复,它提供了各个XXXRepository的泛型实现。

BaseRepository实现IDisposable接口后,以便实施手动回收。

 

→ProductRepository

派生于BaseRepository<Product>基类。
实现IProductRepository接口,它的行为受IProductRepository约束。

 

→DbContextFactory,实现抽象工厂IDbContextFactory接口,用来生产EF上下文实例

它的实现过程保证了在当前线程内获取唯一EF上下文实例。

 

→DbSession,对IDbSession接口的实现

主要做了3件事:
1、提交所有变化
2、拿到各个IXXXRepository类型
3、执行SQL语句

 

→DbSessionFactory,实现IDbSessionFactory接口

它的实现过程保证了在当前线程内获取唯一数据层访问入口IDbSession实例。

 

  IBLL层

IBLL

 

→IBaseService,是所有IXXXService接口的基接口,提供了泛型实现

它的实现避免了各个IXXXService接口的重复部分。

 

→IProductService,对基接口IBaseService<Product>的实现

 

  BLL层

BLL

 

→BaseService,是所有XXXService的基类,提供了泛型实现

他的实现避免了各个XXXService的重复部分。
实现IDisposable接口后,以便实施手动回收。

 

→ProductService,派生于BaseService<Product>基类。
它的行为受实现IProductService接口约束。

 

源码在这里

 

“MVC项目实践,在三层架构下实现SportsStore”系列包括:

MVC项目实践,在三层架构下实现SportsStore,从类图看三层架构

MVC项目实践,在三层架构下实现SportsStore-01,EF Code First建模、DAL层等

MVC项目实践,在三层架构下实现SportsStore-02,DbSession层、BLL层

MVC项目实践,在三层架构下实现SportsStore-03,Ninject控制器工厂等

MVC项目实践,在三层架构下实现SportsStore-04,实现分页

MVC项目实践,在三层架构下实现SportsStore-05,实现导航

MVC项目实践,在三层架构下实现SportsStore-06,实现购物车

MVC项目实践,在三层架构下实现SportsStore-07,实现订单提交

MVC项目实践,在三层架构下实现SportsStore-08,部署到IIS服务器

MVC项目实践,在三层架构下实现SportsStore-09,ASP.NET MVC调用ASP.NET Web API的查询服务

MVC项目实践,在三层架构下实现SportsStore-10,连接字符串的加密和解密

posted @   Darren Ji  阅读(5556)  评论(2编辑  收藏  举报
编辑推荐:
· .NET Core 托管堆内存泄露/CPU异常的常见思路
· PostgreSQL 和 SQL Server 在统计信息维护中的关键差异
· C++代码改造为UTF-8编码问题的总结
· DeepSeek 解答了困扰我五年的技术问题
· 为什么说在企业级应用开发中,后端往往是效率杀手?
阅读排行:
· Deepseek官网太卡,教你白嫖阿里云的Deepseek-R1满血版
· 2分钟学会 DeepSeek API,竟然比官方更好用!
· .NET 使用 DeepSeek R1 开发智能 AI 客户端
· DeepSeek本地性能调优
· 一文掌握DeepSeek本地部署+Page Assist浏览器插件+C#接口调用+局域网访问!全攻略

我的公众号:新语新世界,欢迎关注。

点击右上角即可分享
微信分享提示