MVC的多层架构实例.doc_第1页
MVC的多层架构实例.doc_第2页
MVC的多层架构实例.doc_第3页
MVC的多层架构实例.doc_第4页
MVC的多层架构实例.doc_第5页
已阅读5页,还剩5页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

MVC的多层架构实例 多层架构是什么?多层架构是开发人员在开发过程当中面对复杂且易变的需求采取的一种以隔离控制为主的应对策略,关于多层架构的标准,我认为有一句话是比较有代表性的“每一层都可以单独部署”,最传统,最简单的就是从三层开始的:将整个项目自下而上的分为:数据持久(数据访问)层,逻辑(业务)层,UI(展现)层。数据访问层:负责将数据持久化响应的数据存储设备上,如DataBase,Txt,Excel等。业务逻辑层:负责处理为满足软件需求而订制的一系列的逻辑与业务,如用户在前端下订单之后,整个业务流可能涉及 到,获取用户信息,获取商品信息,获取购物车信息,验证商品可购买数量是否满足本次购买,针对用户身份产生不同的优惠策略,同时会验证 Cookie,Session等端产生数据的有效性,最终才会产生订单,而订单产生之后会涉及到仓储物流等一系列的Erp系统业务,所有的这一套都属于“下订单”这一需求的业务逻辑。展示层:负责与用户交互的界面,良好的用户体验多是使用在这里。学习过Petshop的话,对于三层都不会陌生:但是随着业务的复杂每一层都会有自己的进化,最终有了无数附加在三层之上的框架与开发思想。MVC与MVP:首先我一直认为这两种事属于展现层的,“展现层MCV”,“展现层MVP”。然后我们站在展现层的角度思考一下“Mvc”与“MVP”。Mvc:分为model,Controller,View,相信大家对于他已经很熟悉了,在此不再累述。MVP:MVP有Model-Presenter-View三个层次业务逻辑:从描述上可以看的很清楚,整个自上而下的结构,最复杂,最可能失控的就是业务逻辑层,因为其中包含着许多的不可控因素,每个行业领域的需求都有可能包含自身的领域知识。于是在之后的多层架构发展构成当中,更多的变化与智慧是体现在这里。领域驱动:限于本人才学不能在这里分享太多,以防误导大家,想了解更多可参考园子里的其他大牛,其实没有3,5 年相关经验是很难理解的,个人感觉如果你不理解的话也不会对你有什么影响,因为领域驱动是建立在良好的面相对象分析,边界划分基础之上的,在学习的过程当 中已经能帮助你去学习到足够多的知识了,最终到不到山巅其实已经无所谓了。简单的说,这个思想最重要的是以业务领域为核心进行发散,期望在变更程序的其他部分,不会影响到领域模型,也就是那句话为了“复杂的系统应用程序中业务规则行为方式(就是“领域逻辑”)是会经常变化的,我们要去拥抱这种变化”。结构图:CQRS:是指命令查询职责的分离,是一个小的模式形态,该模式的关键在于:“一个方法要么是用来改变某个对象的状态的,要么就是返回一个结果,这两者不会同时并存”。将整个系统分拆为两个部分:Commands(命令)- 改变某一个对象或整个系统的状态(有时也叫做modifiers或者mutators)。Queries(查询)- 返回值并且不会改变对象的状态。架构图:不管DDD也好,CQRS也好,其实这两种都不会100%适合所有的项目架构的,这就需要架构师结合项目本身特点及需求有所选择,但是其中的思想我们可以运用在项目的任何地方。基于消息的分布式:其实不管使用怎样的架构,加入怎样的架构思想(soa),核心或者是开发者最想达到的就是层次,系统之间的解耦,复杂的东西没人会喜欢。随着系统的发展,我们的程序会涉及到多台服务器,多种终端,同时为了解耦我们引入了基于消息的分布式架构。首先,所以系统的通信基于消息,逻辑联系不会涉及到具体的业务实现,同时消息的传递更加的廉价可适配多种终端。其次,由于所用逻辑只是基于消息实现,迭代的成本也会相对于其他耦合项目更快更方便。展示层:随之Web2.0的到来单一页面展示的信息也更加的丰富,Ajax,js的流行也使得Ui端的操作也愈加变重,于是大家有期望以一种工程的思想去拥 抱这种变化,于是MVVM,js的Mvc框架陆续出现。同时随着移动互联网的兴起,不同终端对于系统的对接也非常重要,于是我们考虑在Ui与Logic之 间引入Application或Service层应对不同终端配置。如:我们在Client Presenter Layer 上加入WCF适配多种终端提交的订单,都是建立在消息基础之上的,楼主之前做电商系统是针对于来自淘宝,天猫,亚马逊订单时,为避免出现对库中订单并发, 产生“超买”情况,采用了在上层Ui与logic层之间引入了OrderChannel层,将不同终端订单进行排队的解决方案。以上是架设一个能够适配不同需求的架构过程,但是真正的真理是需要大家在实践中,错误中汲取的。下面是楼主简单的小分层架构,不妥,不足之处希望大家指导斧正。层次划分:为了实现单独部署,层次解耦所以层次之间是基于接口实现的。DataAccess层引入仓储实现统一DTO操作,实现基于Ef:IRepository: public interface IRepository where T:class IEnumerable FindAll(ExpressionFunc exp); void Add(T entity); void Delete(T entity); void Submit(); 引入RepositoryBase实现接口定义:public class RepositoryBase:IRepository where T:class DbContext context; public RepositoryBase(DbContext _context) context = _context; public RepositoryBase() this.context = new TestDBEntities(); public IEnumerable FindAll(ExpressionFunc exp) return context.Set().Where(exp); public void Add(T entity) context.Set().Add(entity); public void Delete(T entity) context.Set().Remove(entity); public void Submit() context.SaveChanges(); 这对于单一的某个仓储我们单独引入其自身的仓储接口: public interface IUserRepository:IRepository IList GetAllById(int id); bool CheckUserExist(UserTest u); 特定仓储实现: public class UserRepository : RepositoryBase,IUserRepository public IList GetAllById(int id) using (TestDBEntities entities=new TestDBEntities() var users = from u in entities.UserTests where u.ID = id select u; return users.ToList(); public bool CheckUserExist(UserTest u) using (TestDBEntities entities = new TestDBEntities() List users = entities.UserTests.Where(ut = ut.UserName = u.UserName & ut.UserPassword=u.UserPassword).ToList(); return users.Count=0 ? false : true; 在Service层同样建立相关接口适配特种服务:IUserCore: public interface IUserCore CommandStatueEnum UserLogin(IModel model); CommandStatueEnum UserRegister(IModel model); List GetUsers(ExpressionFunc expr); UserCore:public class UserCore : IUserCore #region Structure IUserRepository _repository; public UserCore(IUserRepository repository) this._repository = repository; #endregion public CommandStatueEnum UserLogin(IModel model) try UserLogin u = model as UserLogin; UserTest uTest = new UserTest(); uTest.UserName = u.UserName; uTest.UserPassword = u.Password; if (_repository.CheckUserExist(uTest) return CommandStatueEnum.Succeed; else return CommandStatueEnum.Fail; catch (Exception ex) throw ex; public CommandStatueEnum UserRegister(IModel model) try UserLogin u = model as UserLogin; UserTest uTest = new UserTest() UserName=u.UserName, UserPassword=u.Password; _repository.Add(uTest); _repository.Submit(); return CommandStatueEnum.Succeed; catch (Exception ex) throw ex; public List GetUsers(System.Linq.Expressions.ExpressionFunc expr=null) return _repository.FindAll(expr).ToList(); Controller:public class AccountController : Controller IUserCore userCore; public AccountController(IUserCore _userCore) this.userCore = _userCore; / / GET: /Account/ #region view public ActionResult Home() ViewBag.Users = userCore.GetUsers(u=u.IsUse=1); return View(); public ActionResult Login() return View(); public ActionResult Register() return View(); #endregion #region Post HttpPost public ActionResult Login(UserLogin account) try if (userCore.UserLogin(account) = CommandStatueEnum.Succeed) return RedirectToAction(Home); else return View(); catch (Exception ex) ExceptionModel.IsExcept = true; ExceptionModel.Exception = ex.ToString(); ExceptionModel.CreateTime = DateTime.Now; return View(); HttpPost public ActionResult Register(UserLogin account) try if (userCore.UserRegister(account) = CommandStatueEnum.Succeed) return RedirectToAction(Home); else return View(); catch (Exception ex) ExceptionModel.IsExcept = true; ExceptionModel.Exception = ex.ToString(); ExceptionModel.CreateTime = DateTime.Now; return View(); #endregion 对于接口之间我们通过引入IOC工具解耦:public class MvcApplication : System.Web.HttpApplication protected void Application_Start() AreaRegistration.RegisterAllAreas(); WebApiConfig.Register(GlobalConfiguration.Configuration); FilterConfig.RegisterGlobalFilters(GlobalFilter

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论