【开源】Springboot API 一键生成器
Springboot API 一键生成器
写这个项目,最大的想法就是:不做CRUD 程序猿
Springboot 在我们平时开发项目当中,是如此的常用。然而,比如平时我们写的一些:
- XX 管理系统
- XX 管理后台
- XX XXXX
诸如此类,无非是一张表格、带有分页、非常标准的一个增删改查
页面。很多时候再想,这样重复的工作,能不能有一个东西替我们实现呢?把重复的代码生成,而我关注有 业务逻辑 的地方就行。
欢迎Star,你的支持是我继续的动力!
生成代码示例
首先、你肯定会有一张表,当然,我们这里采用是MySQL。假设我们有一张后台的用户表
前提是,你不能偷懒,要写字段注释。
CREATE TABLE `ums_admin` (
`id` int(11) NOT NULL AUTO_INCREMENT COMMENT '后台管理用户',
`username` varchar(64) NOT NULL COMMENT '用户名',
`password` varchar(64) NOT NULL COMMENT '密码',
`icon` varchar(1024) NOT NULL COMMENT '头像',
`lock` tinyint(1) NOT NULL DEFAULT '1' COMMENT '0锁定1正常使用',
`email` varchar(128) NOT NULL COMMENT '电子邮箱',
`nick_name` varchar(32) NOT NULL COMMENT '昵称',
`note` varchar(64) NOT NULL COMMENT '备注信息',
`create_time` datetime DEFAULT NULL COMMENT '创建时间',
`login_time` datetime DEFAULT NULL COMMENT '最后登录时间',
`status` tinyint(1) NOT NULL DEFAULT '1' COMMENT '逻辑删除标记',
PRIMARY KEY (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=5 DEFAULT CHARSET=utf8mb4;
Controller
- Controller 包含基本的
CRUD
接口。 Restful
风格接口信息,更加容易理解接口含义。Swagger
生成基本的API 文档信息,以及测试接口。- 校验参数完整性!
@Api(tags = "ApiUmsAdminController",description = "后台用户")
@RestController
@RequestMapping("/umsAdmin")
@Validated
public class ApiUmsAdminController {
@Autowired
private UmsAdminService umsAdminService;
/**
* <p>查询所有后台用户
* <p>author: mrc
*
* @return xyz.chaobei.common.api.CommonResult
* @since 2020-10-12 11:18:42
**/
@ApiOperation("查询所有后台用户")
@GetMapping("/")
public CommonResult getAll() {
List<UmsAdminModel> allList = umsAdminService.findAll();
return CommonResult.success(allList);
}
/**
* <p>默认分页请求后台用户
* <p>author: mrc
*
* @param pageAO 分页查询参数
* @since 2020-10-12 11:18:42
* @return xyz.chaobei.common.api.CommonResult
**/
@ApiOperation("默认分页请求后台用户")
@PostMapping("/page")
public CommonResult paging(@RequestBody @ApiParam("分页查询参数") UmsAdminPageAO pageAO) {
Page<UmsAdminModel> allList = umsAdminService.findPage(pageAO);
return CommonResult.success(allList);
}
/**
* <p>保存一个后台用户
* <p>author: mrc
*
* @param params 保存字段
* @since 2020-10-12 11:18:42
* @return xyz.chaobei.common.api.CommonResult
**/
@ApiOperation("保存一个后台用户")
@PostMapping("/")
public CommonResult save(@RequestBody @Valid @ApiParam("保存字段") UmsAdminSaveAO params) {
boolean isSave = umsAdminService.save(params);
return CommonResult.result(isSave);
}
/**
* <p>修改一个后台用户
* <p>author: mrc
*
* @param id 被修改的ID
* @param params 被修改的字段
* @since 2020-10-12 11:18:42
* @return xyz.chaobei.common.api.CommonResult
**/
@ApiOperation("修改一个后台用户")
@PutMapping("/{id}")
public CommonResult update(@PathVariable("id") @ApiParam("被修改的ID") Integer id, @Valid @RequestBody @ApiParam("被修改的字段") UmsAdminSaveAO params) {
boolean isUpdate = umsAdminService.updateById(params,id);
return CommonResult.result(isUpdate);
}
/**
* <p>删除一个后台用户
* <p>author: mrc
*
* @param id 被删除的ID
* @since 2020-10-12 11:18:42
* @return xyz.chaobei.common.api.CommonResult
**/
@ApiOperation("删除一个后台用户")
@DeleteMapping("/{id}")
public CommonResult delete(@Valid @NotNull @PathVariable("id") @ApiParam("被删除的ID") Integer id) {
boolean isDelete = umsAdminService.deleteById(id);
return CommonResult.result(isDelete);
}
}
SaveAO
SaveAO 一般就是前端
填写表单入参的信息
,当然我们能直接使用DO
进行携带参数。那样不安全。AO
将参数从Controller
携带后,通过
javax.validation.Valid
对字段进行校验后、方可进行下一步。
SaveAO
将参数从Controller
传递到Service
处理逻辑Controller
入参的时候,检验SaveAO
所包含的参数。- @NotBlank
- @NotNull
- 略...
@ApiModelProperty
说明参数注释信息
@Getter
@Setter
public class UmsAdminSaveAO {
/**
* 用户名
*/
@NotBlank
@ApiModelProperty("用户名")
private String username;
/**
* 密码
*/
@NotBlank
@ApiModelProperty("密码")
private String password;
/**
* 头像
*/
@ApiModelProperty("头像")
private String icon;
/**
* 0锁定1正常使用
*/
@NotNull
@ApiModelProperty("0锁定1正常使用")
private Integer lock;
/**
* 电子邮箱
*/
@NotBlank
@ApiModelProperty("电子邮箱")
private String email;
/**
* 昵称
*/
@ApiModelProperty("昵称")
private String nickName;
/**
* 备注信息
*/
@ApiModelProperty("备注信息")
private String note;
}
当然。这里的所有参数都是可以自定义的。你想要哪些,就生成哪些~
Service
Service
负责将Controller
传递的AO
复制到DO(Database Object)
。- 调用
Mapper
的方法进行持久化。 Service
返回一个 成功或者失败的标志。- 逻辑异常,抛出一个异常信息【例如这个ID 找不到用户。。。】,全局捕获后,返回给前端进行提示。
@Service
public class UmsAdminServiceimpl implements UmsAdminService {
@Autowired
private UmsAdminMapper umsAdminMapper;
@Override
public List<UmsAdminModel> findAll() {
return umsAdminMapper.selectList(null);
}
@Override
public Page<UmsAdminModel> findPage(UmsAdminPageAO pageAO) {
Page page = new Page(pageAO.getCurrent(),pageAO.getSize());
QueryWrapper wrapper = new QueryWrapper();
wrapper.eq("`username`", pageAO.getUsername());
wrapper.eq("`lock`", pageAO.getLock());
wrapper.eq("`note`", pageAO.getNote());
umsAdminMapper.selectPage(page, wrapper);
return page;
}
@Override
public boolean save(UmsAdminSaveAO params) {
UmsAdminModel model = new UmsAdminModel();
BeanUtils.copyProperties(params,model);
/**
* 你的逻辑写在这里
*/
int num = umsAdminMapper.insert(model);
return SqlHelper.retBool(num);
}
@Override
public boolean updateById(UmsAdminSaveAO params, Integer id) {
UmsAdminModel model = new UmsAdminModel();
BeanUtils.copyProperties(params,model);
/**
* 你的逻辑写在这里
*/
model.setId(id);
int num = umsAdminMapper.updateById(model);
return SqlHelper.retBool(num);
}
@Override
public boolean deleteById(Integer id) {
/**
* 你的逻辑写在这里
*/
int num = umsAdminMapper.deleteById(id);
return SqlHelper.retBool(num);
}
}
Mapper
- 继承
Mybatis-Plus BaseMapper
获得基础CRUD 能力。
public interface UmsAdminMapper extends BaseMapper<UmsAdminModel> {
// 继承mybatis-plus 获得基础crud
}
看完以上生成的代码。是否对你现在的项目有帮助呢?如果有的话~请继续看下去。
RestController 模式
概括一下,我们常用的一般模式按照图解的话,其实就是这样的。
bye-crud-generate
其实就是将这个流程的crud
操作进行生成出来。让我们吧更多的时间放在逻辑上。增删改查用它来生成就好了!
如何使用 bye-crud-generate
# git clone 拉取代码到本地
git clone https://gitee.com/mrc1999/bye-crud-generate.git
# 修改配置文件信息、连接你的数据库
vi config/application.yaml
# 使用maven插件启动这个spring-boot 项目
mvn spring-boot:run
# 测试访问地址
http://localhost:8080/index
选择一个将要生成表
- 访问 http://localhost:8080/index
- 选择你的数据库表格~
选择基础入参字段
PageAO
分页查询所使用的字段。Ins/UpdAO
添加、修改入参的基本字段。- 选择字段的校验规则。目前只是支持简单的非空校验。
填写基本生成信息
- 包括自定义包路径。
- 填写
作者信息
、API 描述
信息、生成路径
等。
一键生成,生成目录如下,一个标准格式的 maven
项目。
test
└── src
└── main
├── java
│ └── xyz
│ └── chaobei
│ ├── controller
│ │ └── ApiUmsAdminController.java
│ ├── mapper
│ │ └── UmsAdminMapper.java
│ ├── model
│ │ └── UmsAdminModel.java
│ ├── pojo
│ │ ├── UmsAdminPageAO.java
│ │ └── UmsAdminSaveAO.java
│ └── service
│ ├── impl
│ │ └── UmsAdminServiceimpl.java
│ └── UmsAdminService.java
└── resources
└── mapper
└── UmsAdminMapping.xml
让生成的API 跑起来
当然,这里只是作为测试,如果你已经有一个 Springboot项目 那么完全可以按需要添加。
在生成代码路径下:
添加maven 依赖
添加一个 pom.xml
maven 依赖文件
https://gitee.com/mrc1999/bye-crud-generate/blob/master/file/pom.xml
<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>xyz.chaobei</groupId>
<artifactId>test</artifactId>
<version>1.0-SNAPSHOT</version>
<!-- springboot 2.3.1 -->
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.1.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<properties>
<java.version>1.8</java.version>
<mybatis.plus.version>3.3.2</mybatis.plus.version>
<swagger2.version>2.9.2</swagger2.version>
</properties>
<dependencies>
<!-- web -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<!-- mybatis-plus -->
<dependency>
<groupId>com.baomidou</groupId>
<artifactId>mybatis-plus-boot-starter</artifactId>
<version>${mybatis.plus.version}</version>
</dependency>
<!-- devtools -->
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
<!-- mysql -->
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
<scope>runtime</scope>
</dependency>
<!-- lombok -->
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
<scope>provided</scope>
</dependency>
<!-- crud-common -->
<dependency>
<groupId>xyz.chaobei</groupId>
<artifactId>bye-crud-common</artifactId>
<version>1.2</version>
</dependency>
<!-- swagger2 -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>${swagger2.version}</version>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>${swagger2.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
</plugins>
</build>
</project>
添加配置文件
添加一个application.yaml
数据库连接配置
https://gitee.com/mrc1999/bye-crud-generate/blob/master/file/application.yaml
server:
port: 8090
spring:
datasource:
driver-class-name: com.mysql.cj.jdbc.Driver
url: jdbc:mysql://192.168.99.100:3306/mall-pro?useUnicode=true&characterEncoding=utf8&serverTimezone=Asia/Shanghai
username: root
password: 123456
添加 swagger 配置
@EnableSwagger2
@Configuration
public class SwaggerConfig {
@Bean
public Docket createApiDocket() {
Docket docket = new Docket(DocumentationType.SWAGGER_2)
// 自定义API 基本信息
.apiInfo(this.defaultInfo())
// 开启一个端点
.select()
// 开启API 生成路径
.apis(RequestHandlerSelectors.basePackage("xyz.chaobei.controller"))
// 选择生成路径
.paths(PathSelectors.any())
.build();
return docket;
}
public ApiInfo defaultInfo() {
return new ApiInfoBuilder()
.title("TEST")
.description("TEST bye-crud-generate")
.version("1.0")
.contact(new Contact("mrc", "https://blogs.chaobei.xyz", "maruichao52@gmail.com"))
.build();
}
}
添加一个启动 main()
方法
https://gitee.com/mrc1999/bye-crud-generate/blob/master/file/DefaultApplication.java
@SpringBootApplication
@MapperScan("xyz.chaobei.mapper")
public class DefaultApplication {
public static void main(String[] args) {
SpringApplication.run(DefaultApplication.class,args);
}
}
启动你IDEA 里面的main()
方法,这个Springboot 项目已经完全跑起来喽~
使用Swagger 测试API
Swagger: http://localhost:8080/swagger-ui.html
首先你需要添加一个
swagger
的基础配置文件。 见上面
使用Swagger 的好处实在是太多了。通过 bye-crud-generate
生成的CRUD 已经配置了详细的文档信息。
当然,你也可以直接在Swagger
测试你的API。
参数具有详细的信息,再也不用测试API 的时候,一边复制字段
,一遍使用 postman
等API 工具编写 API json
参数了。
如何自定义生成
最好的自定义的方式就是:修改源码啦~ 我相信你可以的,按照自己的
代码风格
, 改就完了
生成最灵活的方式在于:自定义。
- 自定义生成
类名名称
例如Entity/Model
等符合你习惯的后缀前缀 - 自定义实体类
包名
- 自定义
数据库数据类型
与JAVA 数据类型的映射关系
详细内容见:config/application.yaml
bycrud:
## 模板对应的生成包路径
packages:
entity: model
mapping: mapper
controller: controller
service: service
serviceImpl: service.impl
saveAO: pojo
pageAO: pojo
## 数据库类型转换为java 类型对应
type:
char: String
varchar: String
text: String
int: Integer
tinyint: Integer
date: Date
datetime: Date
timestamp: Date
bigint: Long
##自定义前缀
prefix:
controller: Api
##自定义后缀
suffix:
entity: Model
saveAO: SaveAO
pageAO: PageAO
进度与后期安排
- 初始化搭建项目~
- 建立页面交互~
- 实现接口生成逻辑~
- 生成
element-ui
基础页面~ 【TODO】
【开源】Springboot API 一键生成器的更多相关文章
- 开源的api文档管理系统
api文档 php 在项目中,需要协同开发,所以会写许多API文档给其他同事,以前都是写一个简单的TXT文本或Word文档,口口相传,这种方式比较老土了,所以,需要有个api管理系统专门来管理这些ap ...
- 开源的API集成测试工具 v0.1.2 - 增强体验
Hitchhiker 是一款开源的 Restful Api 集成测试工具,你可以在轻松部署到本地,和你的team成员一起管理Api. 详细介绍请看: http://www.cnblogs.com/br ...
- Netflix正式开源其API网关Zuul 2
5 月 21 日,Netflix 在其官方博客上宣布正式开源微服务网关组件 Zuul 2.Netflix 公司是微服务界的楷模,他们有大规模生产级微服务的成功应用案例,也开源了相当多的微服务组件(详见 ...
- [No0000198]swagger api一键导入postman
在用postman进行接口测试时,对于参数较多的接口时第一次添加接口参数是比较繁琐的,可利用swagger一键导入api接口,事例如下: 1.获取swagger地址 2.打开postman,点击imp ...
- python实战===国内很简单实用的一些开源的api以及开源项目
原创 2017年03月25日 15:40:59 标签: api / 开源项目 / app / 免费接口 声明 以下所有 API 均由产品公司自身提供,本人皆从网络获取.获取与共享之行为或有侵犯产品 ...
- 开源天气预报api整理
高德天气:https://lbs.amap.com/api/webservice/guide/api/weatherinfo/? github上对开源api的整理:https://github.com ...
- Netflix正式开源其API网关Zuul 2--转
微信公众号:聊聊架构 5 月 21 日,Netflix 在其官方博客上宣布正式开源微服务网关组件 Zuul 2.Netflix 公司是微服务界的楷模,他们有大规模生产级微服务的成功应用案例,也开源了相 ...
- 再见丑陋的 SwaggerUI,这款开源的API文档生成神器界面更炫酷,逼格更高!
一般在使用 Spring Boot 开发前后端分离项目的时候,都会用到 Swagger.Swagger 是一个规范和完整的框架,用于生成.描述.调试和可视化 RESTful 风格的 Web API 服 ...
- 开源的API文档工具框架——Swagger简介
初次接触Swagger是在2017年5月,当时公司正好要对整套系统架构进行重新设计,有同事推荐用这个技术框架来规范后台接口的API文档.当时因为架构重构,涉及改造的技术点太多,一时也就没太多精力,把S ...
随机推荐
- RGB打水印在YUV图片上
一. 概述 将RGB图片打在YUV上需要注意的是, 字体之外应该透明, 否则背景也会被覆盖不好看, 所以RGB必须有透明度, 本测试格式为BMP ARGB8888(也即B是最低字节, A是最高字节 ...
- mybatis-spring-boot-starter 1.3.0 操作实体类的SpringBoot例子
例程下载:https://files.cnblogs.com/files/xiandedanteng/gatling20200428-02.zip 需求:使用mybatis实现对hy_emp表的CRU ...
- docker 停止、启动、删除镜像指令
容器 docker ps // 查看所有正在运行容器 docker stop containerId // containerId 是容器的ID docker ps -a // 查看所有容器 dock ...
- Serverless 初体验:快速开发与部署一个Hello World(Java版)
昨天被阿里云的这个酷炫大屏吸引了! 我等85后开发者居然这么少!挺好奇到底什么鬼东西都是90.95后在玩?就深入看了一下. 这是一个关于Serverless的体验活动,Serverless在国内一直都 ...
- Oracle数据库之体系结构
Oracle数据库管理系统中的3个重要的概念:实例(Instance).数据库(Database)和数据库服务器(Database Server). 实例:是后台进程和内存结构的集合,是Oracle数 ...
- Python3使用钉钉机器人推送消息(签名方式)
import time import hmac import hashlib import base64 import urllib import json import requests impor ...
- JVM强引用、软引用、弱引用、虚引用、终结器引用垃圾回收行为总结
JVM引用 我们希望能描述这样一类对象: 当内存空间还足够时,则能保留在内存中:如果内存空间在进行垃圾收集后还是很紧张,则可以抛弃这些对象. -[既偏门又非常高频的面试题]强引用.软引用.弱引用.虚引 ...
- day52:django:ORM单表/多表操作
目录 1.ORM 2.ORM单表增删改查 13个必知必会的查询接口 filter基于双下划线的模糊查询 3.ORM多表增删改查 ORM 什么是ORM? ORM(object relational ma ...
- spring boot 源码之banner
Banner 使用Spring Boot启动的jar包总是会显示一个Spring的图标.实际我们是可以自定义这个图标.Banner接口定义了打印banner的方法. void printBanner( ...
- Jenkins持续集成git、gitlab、sonarqube(7.0)、nexus,自动化部署实战,附安装包,严禁转载!!!
导读 之前用的都是SVN,由于工作需要用到Git,求人不如求己,技多不压身,多学一项技能,未来就少求别人一次,系统的学一遍,自己搭建一整套环境,自动化部署(自动发版),代码质量检测等等(为啥不用doc ...