三层架构通常意义上就是将整个业务应用划分为:界面层(User Interface layer)、业务逻辑层(Bussiness Logic Layer)、数据访问层(Data access layer)。区分层次的目的即为了“高内聚低耦合”的思想,在软件体系架构中,分层结构是最常见的,也是最重要的一种结构,
界面层也称为表示层,位于最外层,离用户最近,用于显示和接受用户输入的数据,为用户提供一种交互式操作的页面。
业务逻辑层(Business Logic Layer) 无疑是系统架构体系中体现核心价值的部分,它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也即是说它与系统所应对的领域逻辑有关,很多时候,也将业务逻辑层称为领域层。
业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种低耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对其调用的底层而言没有任何影响,如果分层设计的时候,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的抽屉式架构,正因为如此,业务逻辑层的设计对于一个支持可拓展的架构尤为关键,因为它扮演了两个不同的角色。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑之外留给设计师的任务
数据访问层,有时候也被称为是持久层,其功能主要是负责数据库的访问,可以访问数据库系统、二进制文件、文本文档或是XML文档,简单的说法就是实现对数据表中的select/insert/update/delete的操作,如果要加入ORM的元素,那么就会包括对象和数据表之间的mapping,以及对象实体的持久化、
三层与MVC的区别: 很多人容易把三层模式与MVC混淆,三层与mvc最不同的区别在于三层是没有Controller控制器的概念,虽然同样是架构级别的,三层与MVC相同的地方是他们都有一个表现层,但是他们不同的地方在于其他的两个层。 MVC没有把业务的逻辑访问看成是俩个层,这是采用三层架构或MVC搭建程序最主要的区别,