业务逻辑层BLL到底有什么用?

2024-05-07 08:45

1. 业务逻辑层BLL到底有什么用?

1、BLL层全称是 Business Logic Layer
顾名思义,是业务层

2、它是DAL(Data Access Layer,数据访问层)和UI(User Interface)层的连接桥梁.

3、既然称作业务层,必然有他的用处,不仅仅是一个中转的功能.
创建一个用户,可以用以下的逻辑表示:

namespace BLL
class 用户BLL
{
添加结果 AddUser(用户实体)
{
  if(!检查用户名是否合法(用户实体.用户名))return 用户名非法;
  if(!检查用户密码是否合法(用户实体.密码))return 密码非法;
  if(!DAL.检查用户是否存在(用户实体.用户名))return 用户名已经存在;
  int 新用户ID=DAL.添加用户记录(用户实体);
  if(新用户ID>0)return 用户添加成功;
  else reutrn 数据库访问出现错误!
}
}

4、但是在大部分没有严格要求的环境中,我们会习惯于把这些检查代码放在UI层,其实是不对的,从而造就了BLL层看起来就是一个中转的功能的错觉.

业务逻辑层BLL到底有什么用?

2. 业务逻辑层的简述

所谓的三层开发就是将系统的整个业务应用划分为表示层,业务逻辑层和数据访问层,这样有利于系统的开发、维护、部署和扩展。分层是为了实现“高内聚,低耦合”。采用“分而治之”的思想,把问题划分开来各个解决,易于控制,延展和分配资源。业务逻辑层用于做一些有效性验证的工作,以更好地保证程序运行的健壮性。如完成数据添加、修改和查询业务等;不允许指定的文本框中输入空字符串,数据格式是否正确以及数据类型验证;用户权限的合法性判断等;通过以上的诸多判断以决定是否将操作继续向后传递,尽量保证程序的正常运行。

3. 业务逻辑层的作用

业务逻辑层(Business Logic Layer)无疑是系统架构中体现核心价值的部分。它的关注点主要集中在业务规则的制定、业务流程的实现等与业务需求有关的系统设计,也即是说它是与系统所应对的领域(Domain)逻辑有关,很多时候,也将业务逻辑层称为领域层。例如Martin Fowler在《Patterns of Enterprise Application Architecture》一书中,将整个架构分为三个主要的层:表示层、领域层和数据源层。作为领域驱动设计的先驱Eric Evans,对业务逻辑层作了更细致地划分,细分为应用层与领域层,通过分层进一步将领域逻辑与领域逻辑的解决方案分离。业务逻辑层在体系架构中的位置很关键,它处于数据访问层与表示层中间,起到了数据交换中承上启下的作用。由于层是一种弱耦合结构,层与层之间的依赖是向下的,底层对于上层而言是“无知”的,改变上层的设计对于其调用的底层而言没有任何影响。如果在分层设计时,遵循了面向接口设计的思想,那么这种向下的依赖也应该是一种弱依赖关系。因而在不改变接口定义的前提下,理想的分层式架构,应该是一个支持可抽取、可替换的“抽屉”式架构。正因为如此,业务逻辑层的设计对于一个支持可扩展的架构尤为关键,因为它扮演了两个不同的角色。对于数据访问层而言,它是调用者;对于表示层而言,它却是被调用者。依赖与被依赖的关系都纠结在业务逻辑层上,如何实现依赖关系的解耦,则是除了实现业务逻辑之外留给设计师的任务。

业务逻辑层的作用