1. POJO
POJO(Plain Old Java Object)这种叫法是Martin Fowler、Rebecca Parsons和Josh MacKenzie在2000年的一次演讲的时候提出来的。按照Martin Fowler的解释是“Plain Old Java Object”,从字面上翻译为“纯洁老式的java对象”,但大家都使用“简单java对象”来称呼它。具体含义是:有一些private参数作为对象的属性,然后针对每一个参数定义get和set方法供外界访问,没有从任何类继承,也没有实现任何接口,更没有被其它框架侵入的java对象。
public class User {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
2. JavaBean
JavaBean是一种用Java语言写成的可重用组件。JavaBean符合一定规范编写的Java类,不是一种技术,而是一种规范。大家针对这种规范,总结了很多开发技巧,做出很多组件或工具。符合这种规范的类,可以被其它的程序员或者框架使用。
它的方法命名,构造及行为必须符合下面特定约定:
(1)所有属性为private。
(2)这个类必须有一个公共的缺省构造函数。即是提供无参数的构造器。
(3)这个类的属性使用getter和setter来访问,其他方法遵从标准命名规范。
(4)这个类应是可序列化的。实现serializable接口。
因为这些要求是约定而不是实现,所以许多开发者把JavaBean看作遵从特定约定的POJO。
public class UserInfo implements java.io.Serializable{
//实现serializable接口。
private static final long serialVersionUID = 1L;
private String name;
private int age;
//无参构造器
public UserInfo() {
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
//javabean当中可以有其它的方法
public void userInfoPrint(){
System.out.println("");
}
}
POJO和JavaBean两者区别:
POJO是比javabean更纯净的简单类或接口。POJO严格地遵守简单对象的概念,而一些JavaBean中往往会封装一些简单逻辑。POJO的格式是用于数据的临时传递,它只能装载数据,作为数据存储的载体,而不具有业务逻辑处理的能力。而JavaBean虽然数据的获取与POJO一样,但是JavaBean当中可以有其它方法。
3. DAO、DTO、VO、PO、BO
DAO(data access objects)是数据访问对象,DAO一般有接口和该接口的实现类。实现类一般用于操作数据库,如对数据库进行增删改查等操作,使用时一般直接调用公共类DAO。
DTO(data transfer object),VO(value object),PO(persistent object),DAO将POJO持久化为PO,用PO可以对应多个VO和DTO,下面举例说明。
一张表有100个字段,对应的PO包含这100个属性。如果前端界面只要求显示其中10个属性值,后端就没有必要把整个PO对象传递到客户端,这时我们就可以用只有这10个属性的DTO来传递结果到客户端,这样也不会暴露服务端表结构。数据到达客户端时形成了某一数据对象,界面把数据呈现出来,这个数据对象就是VO。
BO(business object)是POJO在业务层的体现,对于业务操作来说,更多的是从业务上来包装对象,比如一个User的BO,可能包括name、age、sex、privilege、group等,这些属性在数据库中可能会在多张表中,因为每一张表对应一个PO,而BO需要这些PO组合起来(或说重新拼装)才能成为业务上的一个完整对象。
4. EJB
EJB(Enterprise JavaBean)EJB是一组JavaBean的组合,组合起来实现了某个企业组的业务逻辑,这不是简单的组合,是实现某项业务功能的协和搭配。打个比方,一身穿着,包括一顶帽子、一件衣服、一条裤子、两只鞋,这穿着就是EJB,其它就是一个个JavaBean。
---------------------------------------------------------------------------------------------
下面再专门解释下VO、DTO、DO、PO 四者之间的关系
领域模型中实体类的四种类型:VO、DTO、DO、PO。
经常会接触到VO,DO,DTO的概念,本文从领域建模中的实体划分和项目中的实际应用情况两个角度,对这几个概念进行简析。
得出的主要结论是:在项目应用中,VO对应于页面上需要显示的数据(表单),DO对应于数据库中存储的数据(数据表),DTO对应于除二者之外需要进行传递的数据。
一、实体类
在日常的Java项目开发中,entity(实体类)是必不可少的,它们一般都有很多的属性,并有相应的setter和getter方法。entity(实体类)的作用一般是和数据表做映射。
再来看下百度百科中对于实体类的定义:
实体类的主要职责是存储和管理系统内部的信息,它也可以有行为,甚至很复杂的行为,但这些行为必须与它所代表的实体对象密切相关。
根据以上定义,我们可以了解到,实体类有两方面内容,存储数据和执行数据本身相关的操作。这两方面内容对应到实现上,最简单的实体类是POJO类,含有属性及属性对应的set和get方法,实体类常见的方法还有用于输出自身数据的toString方法。
二、领域模型中的实体类
领域模型中的实体类分为四种类型:VO、DTO、DO、PO,各种实体类用于不同业务层次间的交互,并会在层次内实现实体类之间的转化。
业务分层为:视图层(VIEW+ACTION),服务层(SERVICE),持久层(DAO)
相应各层间实体的传递如下图:
项目中我们并没有严格遵循这种传递关系,但这种和业务层次的关联对我们理解各实体类的作用是有帮助的。(我们没有接触到PO的原因,我理解为ORM对PO进行了封装)
以下是资料的原文,上图是基于此绘制的。
概念:
VO(View Object):视图对象,用于展示层,它的作用是把某个指定页面(或组件)的所有数据封装起来。
DTO(Data Transfer Object):数据传输对象,这个概念来源于J2EE的设计模式,原来的目的是为了EJB的分布式应用提供粗粒度的数据实体,以减少分布式调用的次数,从而提高分布式调用的性能和降低网络负载,但在这里,我泛指用于展示层与服务层之间的数据传输对象。
DO(Domain Object):领域对象,就是从现实世界中抽象出来的有形或无形的业务实体。
PO(PersistentObject):持久化对象,它跟持久层(通常是关系型数据库)的数据结构形成一一对应的映射关系,如果持久层是关系型数据库,那么,数据表中的每个字段(或若干个)就对应PO的一个(或若干个)属性。
下面按时序建立简单模型来描述上述对象在三层架构应用中的位置。
1. 用户发出请求(可能是填写表单),表单的数据在展示层被匹配为VO。
2. 展示层把VO转换为服务层对应方法所要求的DTO,传送给服务层。
3. 服务层首先根据DTO的数据构造(或重建)一个DO,调用DO的业务方法完成具体业务。
4. 服务层把DO转换为持久层对应的PO(可以使用ORM工具,也可以不用),调用持久层的持久化方法,把PO传递给它,完成持久化操作。
5. 对于一个逆向操作,如读取数据,也是用类似的方式转换和传递,略。
三、项目中的实体类
项目中常见的实体类有VO,DO和DTO,命名规则也常是以相应字符串结尾,如*VO.Java。但是DTO不总是遵循这个规则,而通常与他的用途有关,如写成*Query.java,表示存储了一个查询条件。项目中实体类出现的业务层次也没有这么严格,例如我们可以在视图层就组装一个DO,也可以将一个VO从持久层传出来,所以与业务分层相关联的划分方法显得有些冗余。从项目代码中抽象出的理解是:VO对应于页面上需要显示的数据,DO对应于数据库中存储的数据,DTO对应于除二者之外需要进行传递的数据。