java EE应用概述
1.javaEE应用的分层模型
不管是经典的Java EE架构,还是轻量级的Java EE架构,大致上都可以分为以下几层:
- Damain Object(领域对象)层:该层是由系列的POJO(普通的,传统的,Java对象)组成,这些对象是该系统的Domain Object,往往包含了各自需要实现的业务逻辑方法。
- Dao(Data Access Object,数据访问对象)层:此层是由系列的DAO组件组成,这些Dao实现了对数据库的创建,查询,更新和删除(CRUD,增删改查)等原子操作。
- 业务逻辑层:此层是有一系列的业务逻辑对象组成,这些业务逻辑对象实现了系统所需要的业务逻辑方法,这些业务逻辑方法可能仅仅用于暴露Domain Object对象所实现的业务逻辑方法,也可能是依赖Dao组件实现的业务逻辑方法。
- 控制器层:此层由系列控制器组成,这些控制器用于拦截用户的请求,并调用业务逻辑组健的业务逻辑方法,处理用户的请求,并根据处理结果转发到不同的表现层组件。
- 表现层:此层是由系列的jsp等页面组成,用于获取用户的请求,并负责将处理结果显示出来。
各层Java EE组件之间是以松耦合的方法耦合在一起,各组件并不以硬编码的方法耦合,这种方法是为了应用以后的扩展性。从上到下,上面的组件依赖下面的组件的功能,从下到上,下面的组件支持上面组健的实现。
2.Java EE应用的组件
总体而言,Java EE应用大致包括如下几类组件:
- 表现层组件:主要是负责用户的输入数据,或者向客户端显示系统状态,最常用的表现层技术是JSP,但是JSP并不是唯一的表现层技术。
- 控制器组件:对于Java EE的MVC框架来说,框架提供一个前端核心控制器,而核心控制器用来负责拦截用户的请求,并将请求转发给用户实现的控制器组件,而这些用户实现的控制器组件则负责处理调用业务逻辑方法,处理用户请求。
- 业务逻辑组件:是系统的核心组件,实现系统的业务逻辑,通常,一个业务逻辑方法对应一此用户操作,一个业务逻辑方法应该是一个整体的,应此,要求,业务逻辑方法增加事务性,业务逻辑方法只负责实现业务逻辑,不应该进行数据库的访问。
- Dao组件:也称为数据库访问对象,这个类型的对象比较缺少变化,每个Dao组件都提供Domain Object的创建,查询,更新,删除等操作。这些操作对应数据库中的CRUD等原子操作。当然,如果采用不同的持久层访问技术,Dao组件实现也不同。为了实现业务逻辑层和Dao层的分离,每个Dao组件都提供了接口,业务逻辑组件面向Dao接口编程,从而提供了更好的解耦。
- 领域对象组件:领域对象抽象了系统的对象模型,通常而言,这些领域对象的状态都是保存再数据库中,因此,每个领域对象通常对应一个后多个数据表。
使业务逻辑和Dao操作分开的原因是因为保证业务逻辑方法的实现,与具体的持久层访问技术分离,当系统需要在不同的持久层技术之间切换时,系统的业务逻辑组件无需任何改变。
持久层:
所谓持久,就是把数据保存到可以永久保持的存储设备当中。一般来说,持久更为直接的理解就是对数据库的各种操作,如CRUD(增加,删除,修改,查询),更新等操作,
持久层,就是把持久的动作封装成一个独立的层,这是为了降低功能代码之间的关联。创建一个更清晰的抽象,提高代码的内聚力,降低代码的耦合度,从而增强代码的要劳动局生和可重用性。
实现持久层的框架有: JDBC, Hibernate,Mybatis,JPA等技术。
3.常用的Java EE服务器
采用Struts+Spring+Hibermate这种架构的软件系统,无需专业的Java EE服务器支持,只需要简单的Web服务器就可,Java中常见的Web服务器都是开源的,而且具有很好的稳定性。
常见的Web服务器:
- Tomcat:此服务器和Java结合的最好,时Sun官方推荐的JSP服务器。
- Jetty:另一个优秀的服务器
- Resin:目前最快的JSP,Servlet运行平台,支持EJB个人学习是免费的,但是商用的话是需要交纳相应的费用。
除了常用的Web服务器之外,还有许多的Java EE服务器,相对于Web服务器,Java EE服务器支持更多的Java EE特性,如分布式事务,EJB容器等,常用的Java EE服务器有:
- JBoss:开源的Java EE服务器。
- web Logic和WebSphere:专业的商用的JavaEE服务器,价格不菲。
对于轻量级的Java EE而言,没有必要使用Java EE服务器,简单的Web服务器即可。