java Web项目Service层通用接口和entityVo对象与entity对象转化问题的解决方案

Service层的接口中有一些比较常用方法,一次又一次的在新的Service层中被书写,所以懒惰的程序员又烦了,他们决定写个通用接口来解决这个问题。

有些项目中,实体类即承担接收表单数据的任务,又承担持久化任务,很省心。但有些项目中这两项任务的执行类不是同一个,一个Entity.java来执行数据

持久化的任务,一个EntityVo.java类来执行接收表单数据的任务。那么问题来了:Service层需要的是entityVo对象,而DAO层需要的是entity对象,这两个对象

会有一些相同的属性和方法,也会有一些不同的属性和方法,那么在service层中必然要做entityVo对象到entity对象的转换工作,而这项工作又不属于业务。如果

处理方法与业务混在一起写,代码的清晰度就会受到影响。所以本文中做了这方面的处理,可能并不是最好的方案,但起码比没有处理要好的多。

BaseService.java

package org.lxl.mr.common.base.service;

import java.util.List;

public interface BaseService<EntityVo,PK> {

/**

* 增加

* @param entityVo

*/

public void save(EntityVo entityVo);

/**

* 修改

* @param entityVo

*/

public void update(EntityVo entityVo);

/**

* 通过主键删除

* @param pk

*/

public void deleteByPK(PK pk);

/**

* 删除

* @param entityVo

*/

public void delete(EntityVo entityVo);

/**

* 通过主键查询

* @param pk

* @return

*/

public EntityVo get(PK pk);

/**

* 查询全部

* @return

*/

public List<EntityVo> findAll();

}
使用

UserService.java

package org.lxl.mr.service;

import org.lxl.mr.common.base.service.BaseService;

import org.lxl.mr.vo.UserVo;

public interface UserService extends BaseService<UserVo, String>{

}

这个处理非常简单,就是写个父接口,把常用的方法写在父接口中,子接口没有其他的需要就什么都不用写;有

其他的需要就再写相应的方法即可。

BaseServiceImpl.java

package org.lxl.mr.common.base.service;

import org.lxl.mr.common.base.vo.VoTemplate;

import org.springframework.beans.factory.annotation.Autowired;

public class BaseServiceImpl {

private VoTemplate voTemplate;

@Autowired

public final void setVoTemplate(VoTemplate voTemplate) {

this.voTemplate = voTemplate;

}

public final VoTemplate getVoTemplate(){

return this.voTemplate;

}

}

这个通用方法并不是用来自动实现BaseService接口中的方法的,而是处理entityVo和entity直接转化的问题的。

这是仿造HibernateDaoSupport的写法,注入voTemplate对象。其中voTemplate的get/set方法都是final修饰的,

是不允许子类重写的,保证了注入的正确执行。

VoTemplate.java

package org.lxl.mr.common.base.vo;

import org.springframework.beans.BeanUtils;

import org.springframework.stereotype.Component;

/**

* 本类的作用是解决service层传递的EntityVo对象与dao层

* 使用的Entity对象转换的问题,更轻松,更规范的处理该问题

* @author liuXueLiang

*/

@Component

public class VoTemplate {

/**

* 由程序员自己提供一个回调方法

* @param vo

* @return

*/

public <T> T execute(VoCallback<T> vo){

return vo.doInVo();

}

/**

* 默认的回调方法,将v的属性值复制给t,并将t返回

* @param t    回调对象

* @param v    目标对象

* @return

*/

public <T,V> T defaultExcute(final T t,final V v){

return this.execute(new VoCallback<T>(){

@Override

public T doInVo() {

if(v==null) return null;

BeanUtils.copyProperties(v,t);

return t;

}

});

}

}

VoCallback.java

package org.lxl.mr.common.base.vo;

public interface VoCallback<T> {

T doInVo();

}

使用

package org.lxl.mr.service.impl;

import java.util.ArrayList;

import java.util.List;

import java.util.UUID;

import org.lxl.mr.common.base.service.BaseServiceImpl;

import org.lxl.mr.common.base.vo.VoCallback;

import org.lxl.mr.dao.UserDao;

import org.lxl.mr.pojo.User;

import org.lxl.mr.service.UserService;

import org.lxl.mr.vo.UserVo;

import org.springframework.beans.factory.annotation.Autowired;

import org.springframework.stereotype.Service;

@Service

public class UserServiceImpl extends BaseServiceImpl implements UserService {

private UserDao userDao;

@Autowired

public void setUserDao(UserDao userDao) {

this.userDao = userDao;

}

/**

* 增加,方法一

*/

@Override

public void save(UserVo entityVo) {

User user = new User();

user = super.getVoTemplate().defaultExcute(user, entityVo);

this.userDao.save(user);

}

/**

* 增加,方法二

*/

//    @Override

//    public void save(final UserVo entityVo) {

//

//        //这里是处理entityVo与entity转换的地方

//        User user = super.getVoTemplate().execute(new VoCallback<User>(){

//

//            @Override

//            public User doInVo() {

//                User u = new User();

//                //这句根据主键生成策略决定要、不要、改

//                u.setUuid(UUID.randomUUID().toString().replace("-", ""));

//                u.setUsername(entityVo.getUsername());

//                u.setPassword(entityVo.getPassword());

//                return u;

//            }

//

//        });

//

//        //处理业务

//        this.userDao.save(user);

//    }

/**

* 增加,方法三

*/

//    @Override

//    public void save(UserVo entityVo) {

//        //这里是处理entityVo与entity转换的地方

//        User user = super.getVoTemplate().execute(new UserVoCallback(entityVo));

//        //这里是处理业务的地方

//        this.userDao.save(user);

//    }

/**

* 增加,方法四

*/

//    @Override

//    public void save(UserVo entityVo) {

//        //这里是处理entityVo与entity转换的地方

//        User user = super.getVoTemplate().execute(new UserVoCallback2(entityVo));

//        //这里是处理业务的地方

//        this.userDao.save(user);

//    }

@Override

public void update(UserVo entityVo) {

User user = new User();

user = super.getVoTemplate().defaultExcute(user, entityVo);

this.userDao.update(user);

}

public UserDao getUserDao() {

return userDao;

}

@Override

public void deleteByPK(String pk) {

this.userDao.deleteByPK(pk, UserVo.PK_NAME);

}

@Override

public void delete(UserVo entityVo) {

User user = new User();

user = super.getVoTemplate().defaultExcute(user, entityVo);

this.userDao.delete(user);

}

@Override

public UserVo get(String pk) {

User user = this.userDao.get(pk);

UserVo userVo = new UserVo();

userVo = super.getVoTemplate().defaultExcute(userVo,user);

return userVo;

}

@Override

public List<UserVo> findAll() {

List<User> list = this.userDao.findAll();

List<UserVo> listVo = new ArrayList<UserVo>();

if(list==null) return null;

for(User user : list){

UserVo userVo = new UserVo();

userVo = super.getVoTemplate().defaultExcute(userVo, user);

listVo.add(userVo);

}

return listVo;

}

}

上面的例子以save方法为例,给出了voTemplate处理entityVo与entity转化的4种用法。

方法1

使用voTemplate的defaultExcute方法,简单的从 v -> t 复制属性

方法2

使用voTemplate的excute方法,自定义处理方法。

方法2、3、4都是自定义处理方法,只不过在提供VoCallback<T>的实现类方式上有所差别。

这里是用内部类实现的

方法3

提供一个UserVoCallback.java,实现VoCallback接口

以这个类的对象作为voTemplate.execute的参数来实现的。

UerVoCallback.java

package org.lxl.mr.vo.callback;

import org.lxl.mr.common.base.vo.VoCallback;

import org.lxl.mr.pojo.User;

import org.lxl.mr.vo.UserVo;

public class UserVoCallback implements VoCallback<User> {

private UserVo userVo;

public UserVoCallback(UserVo userVo){

this.userVo = userVo;

}

@Override

public User doInVo() {

if(userVo==null) return null;

User user = new User();

user.setUsername(userVo.getUsername());

user.setPassword(userVo.getPassword());

return user;

}

}

方法4

1) 提供一个VoCallback接口的抽象实现类VoCallbackSupport.java:

VoCallbackSupport.java

package org.lxl.mr.common.base.vo;

public abstract class VoCallbackSupport<T,V> implements VoCallback<T> {

protected V v;

public VoCallbackSupport(V v){

this.v = v;

}

@Override

public abstract T doInVo();

}

2)提供一个UserVoCallback2.java,继承VoCallbackSupport抽象类。

以这个类的对象作为voTemplate.execute的参数来实现的。

UserVoCallback2.java

package org.lxl.mr.vo.callback;

import org.lxl.mr.common.base.vo.VoCallbackSupport;

import org.lxl.mr.pojo.User;

import org.lxl.mr.vo.UserVo;

public class UserVoCallback2 extends VoCallbackSupport<User, UserVo>{

public UserVoCallback2(UserVo v) {

super(v);

}

@Override

public User doInVo() {

User user = new User();

user.setUsername(v.getUsername());

user.setPassword(v.getPassword());

return user;

}

}

这种方式处理entityVo与entity之间转换与传统的方式一样,还是要程序员自己去处理。

它真正的好处是:

1、规范化处理entityVo与entity之间的转换

2、处理entityVo与entity之间转换的代码与业务代码分离,使代码更清晰

3、在entityVo与entity相似度极高,可以直接复制相同属性的情况下,使用VoTemplate

提供的defalutExcute方法一句话即可实现entityVo与entity的转换,如:

User user = super.getVoTemplate().defaultExcute(new User,entityVo);

非常的方便!

觉得我的这个方案可行的小伙伴不妨在项目中用用,有更好的想法记得告诉我,我们一起提高!

原文地址:https://blog.csdn.net/jianmo777/article/details/50342575

原文地址:https://www.cnblogs.com/jpfss/p/10898347.html

时间: 2024-10-24 16:16:28

java Web项目Service层通用接口和entityVo对象与entity对象转化问题的解决方案的相关文章

java web项目DAO层通用接口BaseDao与实现类BaseDaoImpl

在spring+hibernate的web项目中,处理数据层通常会使用Spring框架提供的HibernateTemplate类提供的方法.通常的用法是每一个实体类对应的去写DAO层的接口和实现类.每个实现类中都写hibernateTemp.save(entity).hibernateTemp.update(entity).hibernateTemp.get(id)...这样写固然没错,但存在着大量的重复代码.所以懒惰的程序员烦了,他们要写一个通用的实现类来解决这个问题,让DAO层解放出来.如果

java web项目war包部署,使用tomcat对指定接口设置身份认证

先简单说一下需求: 将一个基于springboot2.0开发的java web项目打成war包,通过tomcat部署到一台linux服务器上,项目相关的一些图片等资源也按照一定规则放置在服务器构建好的目录下.现在需要让用户通过http网页链接的方式(在浏览器端)访问图片,为了访问安全,需要在中间加一层用户认证.认证过程希望尽量简单些,所以就尝试用tomcat自带的身份认证来做. 话不多说,直接上实现流程: 首先,由于要访问本地的静态资源,所以在springboot启动类中加了一项静态资源的映射,

熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器、过滤器等Web组件以及MVC架构模式进行Java Web项目开发的经验。

熟悉基于JSP和Servlet的Java Web开发,对Servlet和JSP的工作原理和生命周期有深入了解,熟练的使用JSTL和EL编写无脚本动态页面,有使用监听器.过滤器等Web组件以及MVC架构模式进行Java Web项目开发的经验. 1.说一说Servlet生命周期(非常重要) Servlet生命周期包括三部分: 初始化:Web容器加载servlet,调用init()方法 只执行一次 处理请求:当请求到达时,运行其service()方法.service()自动调用与请求相对应的doXXX

java web项目答辩答辩题总结

答辩每个人的总分为1.5分.每个人主要问3个问题. 开发流程===>系统架构====>项目模块+功能===>项目得失重定向与转发:?九个隐式对象?get与post的区辨:?jsp有静态包含,动态包含,两者的区辨:?什么是MVC:?web系统架构:? java web项目答辩 1 http协议全名和特点 ------------------------------------------------------ HTTP是一种超文本传输协议(HyperText Transfer Proto

Java web项目的解耦合

以前的项目大多数都是java程序猿又当爹又当妈,又搞前端(ajax/jquery/js/html/css等等),又搞后端(java/mysql/oracle等等). 随着时代的发展,渐渐的许多大中小公司开始把前后端的界限分的越来越明确,前端工程师只管前端的事情,后端工程师只管后端的事情,正所谓术业有专攻,一个人如果什么都会,那么他毕竟什么都不精. 大中型公司需要专业人才,小公司需要全才,但是对于个人职业发展来说,我建议是分开.你要是这辈子就吃java这碗饭,就不要去研究什么css,js等等. 把

做一个完整的Java Web项目需要掌握的技能

原文链接:http://blog.csdn.net/JasonLiuLJX/article/details/51494048 最近自己做了几个Java Web项目,有公司的商业项目,也有个人做着玩的小项目,写篇文章记录总结一下收获,列举出在做项目的整个过程中,所需要用到的技能和知识点,带给还没有真正接触过完整Java Web项目的同学一个比较完整的视角,提供一个所谓的"大局观",也以便于同学们更有针对性地学习.当然,这里所用到的例子项目是非常初级,简单的项目,所以大神们就可以不用往下看

大型Java Web项目的架构和部署问题

一位ID是jackson1225的网友在javaeye询问了一个大型Web系统的架构和部署选型问题,希望能提高现有的基于Java的Web应用的服务能力.由于架构模式和部署调优一直是Java社区的热门话题,这个问题引发了很多热心网友的讨论,其中一些意见对其它大型Web项目也有很好的指导意义.在讨论之初jackson1225这样描述了当前的应用的架构和部署方案: 目前系统架构如下: web层采用struts+tomcat实现,整个系统采用20多台web服务器,其负载均衡采用硬件F5来实现; 中间层采

做一个完整的Java Web项目需要掌握的技能[转]

转自:http://blog.csdn.net/JasonLiuLJX/article/details/51494048 最近自己做了几个Java Web项目,有公司的商业项目,也有个人做着玩的小项目,写篇文章记录总结一下收获,列举出在做项目的整个过程中,所需要用到的技能和知识点,带给还没有真正接触过完整Java Web项目的同学一个比较完整的视角,提供一个所谓的"大局观",也以便于同学们更有针对性地学习.当然,这里所用到的例子项目是非常初级,简单的项目,所以大神们就可以不用往下看了.

在java web项目中集成webservice

公司要求在项目中加入webservice服务,因为项目中使用了spring框架,所以在这里使用与spring兼容性较好的cxf来实现 cxf所需jar包 spring的jar包就不贴了 一:创建webservice服务器 1)创建一个服务接口 package com.service; import javax.jws.WebParam; import javax.jws.WebService; @WebService public interface IHelloWorld { public S