JavaWeb实现统一查询接口的方法

这篇文章主要讲解了JavaWeb实现统一查询接口的方法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。

创新互联总部坐落于成都市区,致力网站建设服务有网站设计、网站建设、网络营销策划、网页设计、网站维护、公众号搭建、微信平台小程序开发、软件开发等为企业提供一整套的信息化建设解决方案。创造真正意义上的网站建设,为互联网品牌在互动行销领域创造价值而不懈努力!

我发现我所有有查询的controller都要调用service层的两个方法 getById和getByKey 参数大致一样

写的时候基本都是复制粘帖。。。 于是idea老提示大量重复代码 好烦啊 于是就改进了一下

让所有有关查询的service实现一个QueryService的接口

接口定义俩方法

import com.jfinal.plugin.activerecord.Page;
public interface QueryService {
  Page getById(String id, String flag);
  Page getByKey(int page, int pageSize, String value, String flag);
}

肯定要用泛型啊 不然强转容易出错 鬼知道我刚才调用的哪的这个方法

然后把service层的那些方法都统一一下参数

然后在一个公共控制器里写个静态方法 那个注解应该可以不用写 反正控制器不认静态方法

@NotAction
static  Page query(QueryService service,Controller controller, String key, String value, String flag, int page, int pageSize) {
  value = value == null ? "" : value;
  Page list;
  if ("id".equals(key)) {
    list = service.getById(value, flag);
  } else if ("key".equals(key)) {
    list = service.getByKey(page, pageSize, value, flag);
  } else {
    list = null;
  }
  if (list == null) {
    controller.renderJson("result", "{'code':'203','info':'unknown key'}");
  } else {
    controller.renderJson("result", "{'code':'103','info':" + Json.getJson().toJson(list) + "}");
  }
  return list;
}

用的时候在控制器里第一个写调用的service对象,这个service一定要实现QueryService接口,第二个就传this,因为查询结束要传给前台的,我也是懒,都写这里了

如果render不写这里的话就把第二个参数删掉,把12-16行的业务代码扔回控制器的方法里写

最后还返回list 我也不知道我想干啥 等我想开了就把返回值删掉算了

看完上述内容,是不是对JavaWeb实现统一查询接口的方法有进一步的了解,如果还想学习更多内容,欢迎关注创新互联行业资讯频道。


网页标题:JavaWeb实现统一查询接口的方法
URL分享:http://hbruida.cn/article/gjhhio.html