实际是我上司把实体类放在了impl模块,但是方法的抽象类在api模块,api为了方便rpc调用没有引用impl模块,导致我api的方法抽象类用不了impl的实体类,如何解决?

api模块不依赖impl模块,实体在impl模块但是api的抽象类要用,那么有什么方法能解决呢

img

实际是我上司把实体类放在了impl模块,但是方法的抽象类在api模块,api为了方便rpc调用没有引用impl模块,导致我api的方法抽象类用不了impl的实体类
按我的方法,是写了vo,把实体类的属性都搬过来,然后方法再用BeanUtils.copyProperties进行覆盖,但我觉得应该有更好的方法,我的同事是让我把实体类搬上去,但是这我上司的代码又不敢乱动,可能有什么代码规范要求我也不是很了解

img

@Override
    public JfSysUserVo getJfSysUser(JfSysUserVo jfSysUserVo) {
        logger.info("开始查询jf用户信息,用户参数:{}", jfSysUserVo.toString());
        JfSysUser jfSysUser = new JfSysUser();
        JfSysUserVo result = new JfSysUserVo();
        BeanUtils.copyProperties(jfSysUserVo, jfSysUser);
        JfSysUser sysUser = baseMapper.getJfSysUser(jfSysUser);
        if (sysUser != null) {
            BeanUtils.copyProperties(sysUser, result);
        }
        return result;
    }

更好的方法去处理api模块用impl的实体类
  • 抽象类 有实现接口嘛?如果它有实现对应的接口,我建议还是放到 impl 模块中
    api 一般放置接口类,虽然抽象类也有一部分待实现的方法,但本质上 它还是个类,正常它们都会实现某个接口,再抽象出一部分公共的逻辑。
    如果你的抽象类没有如上述,建议 还是要重新设计一下,整一个接口类出来
  • 如果抽象类还是要在api里, 那你就要把 抽象类中 获取实体的逻辑,自己再封一个 抽象方法出来, 由impl去实现返回的逻辑,至于返回的对象可以是 api里对外公布的pojo对象

你这样写也没问题,我们项目就是封了一层vo,一层实体,vo放api,实体放dao或impl,中间通过beanutil copy属性,不过要注意这里copy可能是浅copy。