背景
原来项目数据库操作直接写在action层和部分实体类中,action层代码普遍冗长,逻辑结构不清晰,不能很好的对代码进行语义表达。
代码重构简述
通过改写,将数据操作从action层和部分实体类中解耦出来,实现代码之间有一个清晰的逻辑划分。
分action层,service层,dao层3层。其中,
- action层处理客户端(浏览器或手机app)发过来的http请求。主要负责处理与前端相关的一些操作,如:请求的参数验证、数据类型转换、httpsession管理、服务选择(选择合适service进行调用)、数据返回等操作。在这一层尽量少写(或不写)业务的处理逻辑。
- service层主要实现系统内各个业务的处理逻辑。调用单个或多个dao实现系统业务逻辑。例如,
- dao层实现数据库操作。为各个实体类(数据库表)提供crud操作。例如,UserDao提供save、delete、update、list、validate等方法。
为了说明上述分层之间的关系,这里以登录动作举个例子:
首先是html表单发起一个http请求,由后端的LoginAction处理,LoginAction调用UserService的login方法。UserService的login方法里调用UserDao的validate验证用户名密码是否正确,然后再调用DepartmentDao的findById方法返回用户所在部门的部门名称等信息。