Java Web常见的三层结构

  • 表现层:也就是Web层,常见的框架有Spring MVC、Struts2 ,并包括用于展示的界面,如JSP界面;
  • 业务层:Service层,专注于业务逻辑的实现;
  • 持久层:也叫Dao层,常见的框架是Hibernate、MyBatis。负责与数据库的交互,封装数据库的访问细节;从数据库表中读取加载数据并实例化领域对象(Domian Object)也就是从数据库中读取数据,或者返过来将领域对象实例化到数据库中,也就是将数据写入到数据库中。

当服务器接受到来时浏览器的请求后,web层首先开始工作,根据不同的请求创建相应的servlet对请求进行处理转发,业务层在收到来自web层的信息之后,调用持久层,持久层访问数据库后得到返回结果,经过业务层将返回结果填充到显示界面中(JSP中),web层将Jsp界面作为浏览器请求的响应结果返回到浏览器。

工作流程图如下所示:(引用他处图片,侵删)

java ssm和ssh的区别 ssm和javaweb_java ssm和ssh的区别

三层结构在SSM框架中的体现

在用Java开发互联网应用时,SSM框架(Spring + Spring MVC + MyBatis)成为了越来越主流的选择。

轻量级的开发中,常对Web应用分成以下几层:

  • POJO层: 由一组POJO组成,是对系统各种对象的抽象表达。
  • DAO层: 负责数据库的访问,增、删、改、查等,在MyBatis框架中也常被定义为Mapper层。
  • Service层:由业务逻辑对象组成,是不同系统的业务逻辑的具体实现。
  • Controller层:由控制器组成,对来自浏览器的用户请求进行拦截,并调用Service层的响应的业务逻辑组件处理用户请求,并转发返回结果到View层。
  • View层:由JSP界面,PDF文档等组件组成,用于显示系统对用户请求的处理结果。

因此,在常见的轻量级Java Web开发中,通常会将项目建立成如下的结构:

java ssm和ssh的区别 ssm和javaweb_SSM_02


其中SSM框架经常把dao包命名为mapper包,并将mybatis框架的xxxMapper.java和xxxMapper.xml文件放到此包中

java ssm和ssh的区别 ssm和javaweb_数据库_03

  • Java 代码源文件中几个包的作用

包名

名称

作用

DAO

数据访问层(接口)

封装对数据库的操作,与数据操作有关的都放在这里

DTO

数据传输层

用于 service 层与 web 层之间传输,是Entity的一部分或组合

Entity

实体类

一般与数据库的表相对应,封装 dao 层取出来的数据为一个对象

Service

业务逻辑(接口)

写我们的业务逻辑

Service-Impl

业务逻辑具体实现

实现我们业务接口,一般事务控制是写在这里

Controller

MVC控制器

Spring MVC 就是在这里发挥作用的

Mapper

数据库具体操作

包含 xxxMapper.xml(和xxxMapper.java 二者互相对应)

DAO: 里面可以是数据库操作,也可以是文件读写操作,甚至是redis缓存操作。也有人叫做数据持久层。因为Mybatis可以直接在配置文件中实现接口的每个方法,所以不需要DAOImpl。

DTO:刚学框架的人可能不明白这个有什么用,其实就是用于service层与web层之间传输,为什么不直接用entity(pojo)?其实在实际开发中发现,很多时间一个entity并不能满足我们的业务需求,可能呈现给用户的信息十分之多;或者一个 Entity 包含的信息过多,我们需要的信息仅仅是Entity的一部分,为了减少网络传输,这时候就有了dto。 一般我们使用DTO类来继承entity实体类,在DTO类里放一些业务字段,并提供get、set方法。当我们在业务逻辑层或者交互层用到一些数据库中不存在的字段时,我们就需要在DTO类里放这些字段,这些字段的意义就相当于一些经处理过的数据库字段,实质意义就是方便数据交互,提高效率。

Entity:一般与数据库的表相对应,封装dao层取出来的数据为一个对象,也就是我们常说的pojo,一般只在dao层与service层之间传输

可选的额外包:

Exception:自定义异常。

Utils,即utility,工具辅助层,一组通用的代码集合,比如处理多语言功能,网站非法信息过滤等等功能的代码集;

  • resource:存放后端配置文件

配置文件

名称

内容

spring-dao.xml

spring数据连接配置

配置数据库连接池、sqlSessionFactory对象,扫描DAO接口

spring-service.xml

spring 服务配置

扫描service包下注解、配置事务管理器、基于注解的事务

spring-mvc.xml

spring MVC 配置

开启框架注解模式、处理静态资源、配置jsp、扫描Controller

jdbc.properties

数据库连接参数

配置 JDBC、数据库url、用户名、密码等

mybatis-config.xml

mybatis 配置文件

开启自增主键、使用列别名、驼峰转换

log4j.properties

web 日志输出参数

web 日志输出参数

  • webapp:前端页面与配置文件

存放jsp、css等静态文件,web.xml 配置文件主要包含:

配置 Spring 需要加载的配置文件、启用 disapatcher 转发处理所有的请求、指定编码格式

关于几个包之间的关系

  • controller 包是 Spring MVC 的主要文件,其中对来自浏览器的各种请求进行转发和处理。在 controller 中会内置各种 Service 包中的对象,当接收到新的请求的时候,解析 url ,根据注解调用相应的服务来完成请求。
  • entity 包常常与数据库中的表一一对应,dao 包中定义了数据库的基本操作,并在 mapper 包中的 xml 配置文件中完成数据操作的具体实现(也就是增、删、改、查)。Mybatis 可以实现 dao 与 .xml 的自动匹配,这时候就需要把 xxxMapper.xml 和 xxxMapper.java 放在同一个包内。
  • 在 Service 包中定义了各种服务的接口,然后在 Service-Impl 包中对接口进行实现,在实现接口的时候会内置一个 DAO 包中的对象(因为 web 服务的实现肯定是涉及到数据访问的,而数据访问被抽象成了 DAO 包中的对象,所以服务的实现必须借助 DAO 包),然后我们借助 DAO 中的对象所实现的各种数据访问处理方法来实现具体的服务。

SSM框架中各框架的作用

  • MyBatis:持久层框架,负责数据库访问。
  • Spring MVC:表现层框架,把模型、视图、控制器分离,组合成一个灵活的系统。
  • Spring: 整合项目的所有框架,管理各种Java Bean(mapper、service、controller),事务控制。