基于Springboot的BaseService,BaseController

前言:

在做项目时需要对大量的表做增删查改,而其中的逻辑大同小异,所以抽象了一个 BaseService,BaseController来实现所有表的增删查改和一些公用的基础方法。

UML类图:

大体的思路就是在BaseService和BaseController中都使用泛型,到真正创建类的时候才知道具体的对象,对对象进行操作。

代码如下:

BaseEnity(需要使用BaseService方法的实体必须实现这些抽象方法)

package com.honeywell.tms.entity.base;

public abstract class BaseEntity {
public abstract boolean ValidateEmpty();
public abstract boolean ValidateUnique();
public abstract boolean AutoFill();
public abstract Object getKey();
public abstract String getText();
}

BaseMapper

逆向后得到的mapper方法都是相同的,所以我把它抽象出来了。

package com.honeywell.tms.dao.base;

import com.honeywell.tms.entity.CompanyEntity;
import com.honeywell.tms.entity.base.BaseEntity;
import org.apache.ibatis.annotations.Param; import java.util.List;
//所有被BaseService方法调用的dao都需要实现这个接口
public interface BaseMapper<E extends BaseEntity> {
int deleteByPrimaryKey(@Param(value="ID")Object ID);//在Mapper文件中的占位符的关键字就是value的值 int insert(E record); int insertSelective(E record); E selectByPrimaryKey(@Param(value="ID") Object ID); List<E> selectAll(); int updateByPrimaryKeySelective(E record); int updateByPrimaryKey(E record);
}

BaseService方法如下

package com.honeywell.tms.service.base;

import com.github.pagehelper.PageHelper;
import com.github.pagehelper.PageInfo;
import com.honeywell.tms.dao.base.BaseMapper;
import com.honeywell.tms.entity.base.BaseEntity;
import com.honeywell.tms.entity.base.ResponseEntity;
import com.honeywell.tms.entity.base.ValueTextEntity;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import java.util.UUID; public class BaseService<E extends BaseEntity> {//一些提取了一些公用的Service方法,使用前必须通过init()方法注入相应的Mapper
BaseMapper dao; //在子类构造函数中调用,指明具体的dao层
public void init(BaseMapper mapper){
dao=mapper;
}
//分页获取
public ResponseEntity getByPage(int pageNum,int pageSize) {
PageHelper.startPage(pageNum,pageSize,true);
ResponseEntity responseEntity=new ResponseEntity();
List<E> pageList=dao.selectAll();//这个不是获取到的entity的集合了
PageInfo<E> entityList=new PageInfo<>(pageList);
pageList=entityList.getList();
long count=entityList.getTotal();;
responseEntity.setData(pageList);
responseEntity.setTotal(String.valueOf(count));
return responseEntity;
} //批量增加
public ResponseEntity batchSave(List<E> list) {
ResponseEntity responseEntity=new ResponseEntity();
StringBuffer message=new StringBuffer();
int row=0;
for(E j:list){
row++;
if(!j.ValidateEmpty()){
message.append("第"+row+"行插入失败,请检查是否有违规的空值+\n");
continue;
}
if(!j.ValidateUnique()){
message.append("第"+row+"行已经存在,插入失败\n");
}
j.AutoFill();
dao.insert(j);
}
responseEntity.setMessage(message.toString());
return responseEntity;
} //批量更新
public ResponseEntity batchUpdate(List<E> list) {
ResponseEntity responseEntity=new ResponseEntity();
StringBuffer message=new StringBuffer();
int row=0;
for(E j:list){
row++;
if(!j.ValidateEmpty()){
message.append("第"+row+"行更新失败,请检查是否有违规的空值+\n");
continue;
}
if(!j.ValidateUnique()) {
message.append("第" + row + "行已经存在,更新失败\n");
}
j.AutoFill();
StringToUUID(j);
int back=dao.updateByPrimaryKeySelective(j);//不为空的才更新,为空的不更新。
System.out.println(back);
}
responseEntity.setMessage(message.toString());
return responseEntity;
} //批量删除
public ResponseEntity batchDestroy(List<E> list) {
ResponseEntity responseEntity=new ResponseEntity();
StringBuffer message=new StringBuffer();
int row=0;
for(E j:list) {
row++;
try{
StringToUUID(j);
int count=dao.deleteByPrimaryKey(j.getKey());
}catch (Exception e){
System.out.println(e.getMessage());
message.append("第"+row+"删除失败,请先删除相关引用\n");
}
}
responseEntity.setMessage(message.toString());
return responseEntity;
}
//获取ValueText模型
public ResponseEntity getVTModel(){
ResponseEntity responseEntity=new ResponseEntity();
List<E> list=dao.selectAll();
List<ValueTextEntity> vtList=new ArrayList<>();
for(E j:list){
ValueTextEntity vtEntity=new ValueTextEntity();
vtEntity.setText(j.getText());
vtEntity.setValue(j.getKey().toString());
vtList.add(vtEntity);
}
responseEntity.setListData(vtList);
return responseEntity; }
//将前端页面传来的字符串转为UUID,前提条件是相应属性的名称必须包含"ID"
public Object StringToUUID(Object obj ){
Field[] fields=obj.getClass().getDeclaredFields();
try {
for (Field field : fields) {
field.setAccessible(true);
if (field.getName().contains("ID")) {
Object value = field.get(obj);
Object uid= UUID.fromString(value.toString());
field.set(obj,uid);
}
}
}catch (Exception e){
System.out.println(e.getMessage());
}
return null;
} }

BaseController

package com.honeywell.tms.controller.base;

import com.alibaba.fastjson.JSONArray;
import com.honeywell.tms.entity.CompanyEntity;
import com.honeywell.tms.entity.base.BaseEntity;
import com.honeywell.tms.entity.base.ResponseEntity;
import com.honeywell.tms.service.base.BaseService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody; import javax.servlet.http.HttpServletRequest;
import java.lang.reflect.ParameterizedType;
import java.util.*; public class BaseController<E extends BaseEntity> {
private BaseService<E> service;
private static final String models="models"; //初始化
public void init(BaseService service){
this.service=service;
}
//查询
public Map Read(HttpServletRequest request){
String pageSkip=request.getParameter("pageSkip");
String pageSize=request.getParameter("pageSize");
int skip=Integer.valueOf(pageSkip);
int size=Integer.valueOf(pageSize);
int pageNum=skip/size+1;
ResponseEntity responseEntity=service.getByPage(pageNum,size);
return responseEntity.getMap();
} //增加
public Map Create(HttpServletRequest request){
ResponseEntity responseEntity;//返回的实体
List<E> dataList=getModel(request);
responseEntity=service.batchSave(dataList);
responseEntity.setData(dataList);
return responseEntity.getMap();
} //更新
public Map Update(HttpServletRequest request){
ResponseEntity responseEntity;//返回的实体
List<E> dataList=getModel(request);
responseEntity=service.batchUpdate(dataList);
responseEntity.setData(dataList);
return responseEntity.getMap();
} //删除
public Map Destroy(HttpServletRequest request){
ResponseEntity responseEntity;//返回的实体
List<E> dataList=getModel(request);
responseEntity=service.batchDestroy(dataList);
return responseEntity.getMap();
} //获取ValueText模型
public List getVTModel(){
ResponseEntity responseEntity=service.getVTModel();
return responseEntity.getListData();
} //从request中获取实体
public List<E> getModel(HttpServletRequest request){
String json=request.getParameter(models);
return JSONArray.parseArray(json,createModel());
} //获取实列的类信息
public Class createModel() {
try {
ParameterizedType ptype = (ParameterizedType) this.getClass().getGenericSuperclass();
Class clazz = (Class<E>) ptype.getActualTypeArguments()[0];
E o = (E) clazz.newInstance();
return o.getClass();
}catch (Exception e){
System.out.println(e.getMessage());
}
return null; }
}

使用(用了公司这个实体举例)

公司的实体:

package com.honeywell.tms.entity;

import com.honeywell.tms.dao.CompanyMapper;
import com.honeywell.tms.entity.base.BaseEntity;
import org.springframework.beans.factory.annotation.Autowired; import java.util.Date;
import java.util.UUID; public class CompanyEntity extends BaseEntity {
@Autowired
CompanyMapper dao; private Object COMPANY_ID; private String COMPANY_CODE; private String COMPANY_NAME; private String COMPANY_ADDR; private String CREATED_BY; private String UPDATE_BY; private Date CREATED_DATE; private Date UPDATE_DATE; public Object getCOMPANY_ID() {
return COMPANY_ID;
} public void setCOMPANY_ID(Object COMPANY_ID) {
this.COMPANY_ID=COMPANY_ID;
} public String getCOMPANY_CODE() {
return COMPANY_CODE;
} public void setCOMPANY_CODE(String COMPANY_CODE) {
this.COMPANY_CODE = COMPANY_CODE == null ? null : COMPANY_CODE.trim();
} public String getCOMPANY_NAME() {
return COMPANY_NAME;
} public void setCOMPANY_NAME(String COMPANY_NAME) {
this.COMPANY_NAME = COMPANY_NAME == null ? null : COMPANY_NAME.trim();
} public String getCOMPANY_ADDR() {
return COMPANY_ADDR;
} public void setCOMPANY_ADDR(String COMPANY_ADDR) {
this.COMPANY_ADDR = COMPANY_ADDR == null ? null : COMPANY_ADDR.trim();
} public String getCREATED_BY() {
return CREATED_BY;
} public void setCREATED_BY(String CREATED_BY) {
this.CREATED_BY = CREATED_BY == null ? null : CREATED_BY.trim();
} public String getUPDATE_BY() {
return UPDATE_BY;
} public void setUPDATE_BY(String UPDATE_BY) {
this.UPDATE_BY = UPDATE_BY == null ? null : UPDATE_BY.trim();
} public Date getCREATED_DATE() {
return CREATED_DATE;
} public void setCREATED_DATE(Date CREATED_DATE) {
this.CREATED_DATE = CREATED_DATE;
} public Date getUPDATE_DATE() {
return UPDATE_DATE;
} public void setUPDATE_DATE(Date UPDATE_DATE) {
this.UPDATE_DATE = UPDATE_DATE;
} @Override
public boolean ValidateEmpty() {
if(this.COMPANY_CODE==null||this.COMPANY_CODE.equals("")){
return false;
}
if(this.COMPANY_NAME==null||this.COMPANY_NAME.equals("")){
return false;
}
return true;
}
@Override
public boolean ValidateUnique() {
return true;
} @Override
public boolean AutoFill(){
//ID为空说明是新增操作,
if(getCOMPANY_ID()==null){
this.setCOMPANY_ID(UUID.randomUUID());
this.setCREATED_BY("admin");
this.setCREATED_DATE(new Date());
}
this.setUPDATE_BY("admin");
this.setUPDATE_DATE(new Date());
return true;
} @Override
public Object getKey() {
return this.COMPANY_ID;
}
@Override
public String getText() {
return this.COMPANY_NAME;
}
}

公司的mapper,只需要继承BaseMapper

package com.honeywell.tms.dao;

import com.honeywell.tms.dao.base.BaseMapper;
import com.honeywell.tms.entity.CompanyEntity;
import com.honeywell.tms.entity.base.BaseEntity; public interface CompanyMapper extends BaseMapper<CompanyEntity> { }

公司的Service

(继承BaseService,指明相应的实体,构造注入相应的Service)

package com.honeywell.tms.service;
import com.honeywell.tms.dao.CompanyMapper;
import com.honeywell.tms.entity.CompanyEntity;
import com.honeywell.tms.service.base.BaseService;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; @Service
public class CompanyService extends BaseService<CompanyEntity> {
private CompanyMapper dao;//如果此处出现红色波浪线 Settings - Editor - Inspections - Spring - Spring Core - Code - Autowiring for Bean Class 勾去掉
@Autowired
public CompanyService(CompanyMapper mapper){//这里必须要使用构造注入。
this.dao=mapper;
init(dao);
} }

公司的Controller

(继承BaseController并构造注入相应的Service就行了,一定要构造注入哟。这里其实映射也可以写在BaseController里面,但是项目用了Swagger,它不支持。)

package com.honeywell.tms.controller;

import com.honeywell.tms.controller.base.BaseController;
import com.honeywell.tms.entity.CompanyEntity;
import com.honeywell.tms.service.CompanyService;
import com.honeywell.tms.service.base.BaseService;
import com.honeywell.tms.utils.consts.Response;
import io.swagger.annotations.Api;
import io.swagger.annotations.ApiOperation;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;
import org.springframework.web.bind.annotation.RestController; import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import java.util.List;
import java.util.Map; @Api(value="/Company",tags = "公司模块")
@RestController
@RequestMapping("/Company")
public class CompanyController extends BaseController<CompanyEntity> {//继承BaseController后可以调用一些基本的方法,不过需要注入相应的Service
private CompanyService service;
@Autowired
public CompanyController(CompanyService service){
init(service);
} @RequestMapping("/DownloadTemplate")
@ApiOperation(value = "公司模板下载",notes = "直接下载excel模板")
@ResponseBody
public void DownloadTemplate(HttpServletResponse httpServletResponse){
return;
} @RequestMapping("/Read")
public Map Read(HttpServletRequest request){
return super.Read(request);
}
@RequestMapping("Create")
public Map Create(HttpServletRequest request){
return super.Create(request);
} @RequestMapping("/Update")
public Map Update(HttpServletRequest request){
return super.Update(request);
} @RequestMapping("/Destroy")
public Map Destroy(HttpServletRequest request) {
return super.Destroy(request);
} @RequestMapping("/getVTModel")
public List getVTModel(HttpServletRequest request){
return super.getVTModel();
} }

总结:总体来说较为满意的,能够实现基本的增删改查和一些基本的方法。缺点是大多都是用继承,没有面向接口编程。UML类图画的不够好,有什么意见或修改的地方请多多指教。

基于Springboot的BaseService和BaseController的更多相关文章

  1. 基于SpringBoot搭建应用开发框架(二) —— 登录认证

    零.前言 本文基于<基于SpringBoot搭建应用开发框架(一)——基础架构>,通过该文,熟悉了SpringBoot的用法,完成了应用框架底层的搭建. 在开始本文之前,底层这块已经有了很 ...

  2. SpringData 基于SpringBoot快速入门

    SpringData 基于SpringBoot快速入门 本章通过学习SpringData 和SpringBoot 相关知识将面向服务架构(SOA)的单点登录系统(SSO)需要的代码实现.这样可以从实战 ...

  3. 基于SpringBoot开发一个Restful服务,实现增删改查功能

    前言 在去年的时候,在各种渠道中略微的了解了SpringBoot,在开发web项目的时候是如何的方便.快捷.但是当时并没有认真的去学习下,毕竟感觉自己在Struts和SpringMVC都用得不太熟练. ...

  4. Shiro 核心功能案例讲解 基于SpringBoot 有源码

    Shiro 核心功能案例讲解 基于SpringBoot 有源码 从实战中学习Shiro的用法.本章使用SpringBoot快速搭建项目.整合SiteMesh框架布局页面.整合Shiro框架实现用身份认 ...

  5. 基于SpringBoot从零构建博客网站 - 技术选型和整合开发环境

    技术选型和整合开发环境 1.技术选型 博客网站是基于SpringBoot整合其它模块而开发的,那么每个模块选择的技术如下: SpringBoot版本选择目前较新的2.1.1.RELEASE版本 持久化 ...

  6. 基于Springboot集成security、oauth2实现认证鉴权、资源管理

    1.Oauth2简介 OAuth(开放授权)是一个开放标准,允许用户授权第三方移动应用访问他们存储在另外的服务提供者上的信息,而不需要将用户名和密码提供给第三方移动应用或分享他们数据的所有内容,OAu ...

  7. 基于springboot构建dubbo的入门demo

    之前记录了构建dubbo入门demo所需的环境以及基于普通maven项目构建dubbo的入门案例,今天记录在这些的基础上基于springboot来构建dubbo的入门demo:众所周知,springb ...

  8. 基于springboot+bootstrap+mysql+redis搭建一套完整的权限架构【六】【引入bootstrap前端框架】

    https://blog.csdn.net/linzhefeng89/article/details/78752658 基于springboot+bootstrap+mysql+redis搭建一套完整 ...

  9. 基于springboot的SSM框架实现返回easyui-tree所需要数据

    1.easyui-tree easui-tree目所需要的数据结构类型如下: [ { "children": [ { "children": [], " ...

随机推荐

  1. android surfaView surfaHolder video 播放

    主文件 package cn.com.sxp;import android.app.Activity;import android.media.AudioManager;import android. ...

  2. 快速掌握mongoDB(二)——聚合管道和MapReduce

    上一节简单介绍了一下mongoDB的增删改查操作,这一节将介绍其聚合操作.我们在使用mysql.sqlserver时经常会用到一些聚合函数,如sum/avg/max/min/count等,mongoD ...

  3. [记录]FIO测试磁盘iops性能

    FIO测试磁盘iops性能 1.SATA和SAS盘原生IOPS如下: 2.RAID磁盘阵列对应的写惩罚级别: 3.计算功能性IOPS公式如下: 功能性 IOPS=(((总原生 IOPS×写 %))/( ...

  4. Windows Presentation Foundation (WPF) 项目中不支持xxx的解决

    一般Windows Presentation Foundation (WPF) 项目中不支持xxx都是由于没引用相应的程序集导致,比如Windows Presentation Foundation ( ...

  5. Code Review最佳实践

    我一直认为Code Review(代码审查)是软件开发中的最佳实践之一,可以有效提高整体代码质量,及时发现代码中可能存在的问题.包括像Google.微软这些公司,Code Review都是基本要求,代 ...

  6. CSingleLock

    CSingleLock通常和CCriticalSection配合使用.总结这种用法

  7. Spring Cloud 之 Zuul基础.

    一.概述  API 网关是一个更为智能的应用服务器,它的定义类似于面向对象设计模式中的 Facade 模式,它的存在就像是整个微服务架构系统的门面一样,所有的外部客户端访问都需要经过它来进行调度和过滤 ...

  8. C#控制台打开VM虚拟机

    添加引用->VixCOM.dll (在vix文件夹下) VixWrapper.cs using System; using System.Collections.Generic; using S ...

  9. php if语句

    一.前言 if语句 是几乎所有编程语言都有的函数. 当然我们最好的php这么最好的语言也有啦~ 二.搞起! 直接上代码不多哔哔.talk is cheap show me the code 2.1 i ...

  10. HashSet源码分析:JDK源码系列

    1.简介 继续分析源码,上一篇文章把HashMap的分析完毕.本文开始分析HashSet简单的介绍一下. HashSet是一个无重复元素集合,内部使用HashMap实现,所以HashMap的特征耶继承 ...