SpringJpa CRUD 代码生成器
利用业余时间撸了一个Spring Jpa代码生成器jpa-codegen。
简介
这是一款基于Freemarker模板驱动的代码生成器。
依据现有的实体类代码,自动生成CRUD代码,解放双手,加快开发速度。
生成的代码包括但不仅限于(可以自定义生成模块)
- Form表单代码
- Repository代码
- Service代码
- Controller代码
SpringBoot使用示例
克隆示例项目,体会解放双手的美妙感受!
如何使用
导入仓库
maven {
url 'https://dl.bintray.com/gcdd1993/maven'
}
dependencies {
// jpa code generator
testCompile 'io.github.gcdd1993:jpa-codegen:v1.0.1'
testCompile 'org.freemarker:freemarker:2.3.28'
}
配置代码生成器
配置文件
## 作者
author=gcdd1993
## 代码注释
comments=code generated by jpa-codegen
## 是否覆盖原文件,除非特殊情况,不然请不要覆盖
cover=false
## 代码模板目录
template.dir=src/test/resources/template/
## 实体类包名 Deprecated从v1.0.1开始从配置文件中移除
- entity.package=com.maxtropy.sample.entity
## 实体类标识符 Deprecated从v1.0.1开始从配置文件中移除
- entity.flag=entity
## 以下配置是模块配置(格式 模块名.配置名),必须在模板目录下提供与模块名相同的模板
## 生成的代码后缀
repository.suffix=Repository
## 模板名称
repository.template=repository.ftl
## 模块标识符
repository.flag=entity.repo
service.suffix=Service
service.template=service.ftl
service.flag=service
form.suffix=Form
form.template=form.ftl
form.flag=form
controller.suffix=Controller
controller.template=controller.ftl
controller.flag=web
其中
repository.suffix=Repository
repository.template=repository.ftl
repository.flag=entity.repo
是模块配置,什么是模块?
编写代码模板
模板主要基于Freemarker,如Spring Boot2.x代码模板可以像下面这样
package ${packageName};
import ${entity.packageName}.${entity.className};
import org.springframework.data.jpa.repository.JpaRepository;
import org.springframework.data.querydsl.QuerydslPredicateExecutor;
<#list imports as import>
import ${import};
</#list>
/**
* repository for ${entity.className} generated by jpa-codegen
* ${comments}
*
* @author ${author}
* Created On ${date}.
*/
public interface ${className} extends JpaRepository<${entity.className}, ${entity.id.className}>, QuerydslPredicateExecutor<${entity.className}> {
}
编写生成器入口
在test模块中编写生成器入口,如
public class Codegen {
@Test
public void generate() {
new CodeGenerator("src/test/resources/codegen.properties")
.registerRender("repository")
.generate();
}
}
然后运行generate(),在项目目录下将会生成


生成的代码完全由模板以及实体类信息决定。
如何编写模板?
模板完全基于FreeMarker以及实体类信息,FreeMarker参考FreeMarker Docs
支持的元素定义如下
基本信息
| Freemarker元素 | 解释 | 示例输出 |
|---|---|---|
${ftlName} |
模板名称 | controller.ftl |
${ftlPath} |
模板目录 | src/main/resources/template/ |
${savePath} |
保存路径 | src/main/resources/io/github/gcdd1993/controller |
${packageName} |
java文件包名 | io.github.gcdd1993.controller |
${className} |
java文件类名 | UserController |
${author} |
作者 | gaochen |
${date} |
创建日期,默认为当前日期 | 2019/6/23 |
${comments} |
注释信息 | generated by jpa-codegen |
${imports} |
java文件引入信息 | org.springframework.beans.factory.annotation.Autowired |
实体信息
| Freemarker元素 | 解释 | 示例输出 |
|---|---|---|
${entity.className} |
实体类名,class.getSimpleName() |
User |
${entity.packageName} |
实体包名,class.getPackage().getName() |
io.github.gcdd1993 |
${entity.tableName} |
实体表名,@Table(name="") |
sys_user |
${entity.id.className} |
实体主键类名,@Id注释的字段的类名 |
Integer |
${entity.id.packageName} |
实体主键包名,@Id注释的字段的包名 |
java.lang |
${entity.fields.className} |
实体所有字段(只支持基本类型)类名 | String |
${entity.fields.packageName} |
实体所有字段(只支持基本类型)包名 | java.lang |
${entity.fields.name} |
实体所有字段(只支持基本类型)属性名 | name |
${entity.fields.annotations.className} |
实体所有字段注解的类名 | Id |
${entity.fields.annotations.packageName} |
实体所有字段注解的包名 | javax.persistence |
自定义配置
除了以上默认的信息之外,可能会有额外的信息需要填入生成的代码中,jpa-codegen提供直接将配置文件中的配置渲染到模板的能力。
例如在配置文件autogen.properties写下一行
custom.additional.comment=this is additional comment
在模板中可以使用${otherParams.additional_comment}获取到该配置。
要注意的是:自定义配置使用custom开头,后面的配置会将.替换为_作为FreeMarker模板的key,例如上述的additional.comment使用${otherParams.additional_comment}获取。
什么是模块?
由于代码千变万化,为了尽可能的做到通用性,jpa-codegen将每一种类型的代码抽象为模块,每一个模块将使用各自的模板,依照实体信息生成代码。
需要为模板配置一下信息:
- repository.suffix=Repository
模块类名后缀,生成的类名规则由实体类名+后缀构成
- repository.template=repository.ftl
模块使用的Freemarker模板
- repository.flag=entity.repo
模块标识符,生成的代码包名由实体类将实体标识符替换为模块标识符来确认。
如
- 实体包名:
io.github.gcdd1993.entity - 实体标识符:
entity - 模块标识符:
entity.repo
则生成的repository代码包名为 --> io.github.gcdd1993.entity.repo
SpringJpa CRUD 代码生成器的更多相关文章
- 应用程序框架实战三十六:CRUD实战演练介绍
从本篇开始,本系列将进入实战演练阶段. 前面主要介绍了一些应用程序框架的概念和基类,本来想把所有概念介绍完,再把框架内部实现都讲完了,再进入实战,这样可以让初学者基础牢靠.不过我的精力很有限,文章进度 ...
- [NHibernate]代码生成器的使用
目录 写在前面 文档与系列文章 代码生成器的使用 总结 写在前面 前面的文章介绍了nhibernate的相关知识,都是自己手敲的代码,有时候显得特别的麻烦,比如你必须编写持久化类,映射文件等等,举得例 ...
- CRUD生成器DBuilder设计与实现
源码位于github:https://github.com/lvyahui8/dbuilder.git .文中图片如果太小看不清楚,请右键点击“在新标签页中打开”即可看到原图 有兴趣还可以加QQ群交流 ...
- 【转】20个Java 代码生成器
From: http://www.cnblogs.com/skyme/archive/2011/12/22/2297592.html 1.1 CodeSmith 一款人气很旺国外的基于模板的dotne ...
- 尝试Spring Data Jpa--告别CRUD
前言 说到我们的web开发架构分层中,持久层是相对底层也是相对稳定的一层,奠定好根基后,我们才能专注于业务逻辑和视图开发.而自从ORM思想蔓延开来后,全自动ORM的Hibernate和半自动ORM的M ...
- mybatis自定义代码生成器(Generator)——自动生成model&dao代码
花了两天的时间研究了下mybatis的generator大体了解了其生成原理以及实现过程.感觉generator做的非常不错,给开发者也留足了空间.看完之后在generator的基础上实现了自定义的生 ...
- .NET Core实战项目之CMS 第十二章 开发篇-Dapper封装CURD及仓储代码生成器实现
本篇我将带着大家一起来对Dapper进行下封装并实现基本的增删改查.分页操作的同步异步方法的实现(已实现MSSQL,MySql,PgSQL).同时我们再实现一下仓储层的代码生成器,这样的话,我们只需要 ...
- mybatis-plus的代码生成器
简介:构建自定义mybatis-plus模板,自动生成mybatis,entity,mapper,service,controller 项目源码:https://github.com/y369q369 ...
- 一套基于SpringBoot+Vue+Shiro 前后端分离 开发的代码生成器
一.前言 最近花了一个月时间完成了一套基于Spring Boot+Vue+Shiro前后端分离的代码生成器,目前项目代码已基本完成 止步传统CRUD,进阶代码优化: 该项目可根据数据库字段动态生成 c ...
随机推荐
- 上周 GitHub 热点速览 vol.07:GitHub 官方 CLI beta 版已发布
摘要:GitHub Trending 上周看点,GitHub 官宣 CLI 已发布 beta 版,前端新晋高性能打包神器 esbuild 宣战 Webpack&Parcel,微软.Facebo ...
- Go语言实现:【剑指offer】数值的整数次方
该题目来源于牛客网<剑指offer>专题. 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 保证base和exponent不 ...
- 二. 大数据常用的算法和数据结构 <<大数据日知录>> 读书笔记
基本上是hash实用的各种举例 布隆过滤器 Bloom Filter 常用来检测某个原色是否是巨量数据集合中的成员,优势是节省空间,不会有漏判(已经存在的数据肯定能够查找到),缺点是有误判(不存在的数 ...
- Zookeeper 介绍 原理
简介: ZooKeeper是一个分布式的,开放源码的分布式应用程序协调服务. 它Google的Chubby一个开源的实现,在分布式协调技术方面做得比较好的就是Google的Chubby还有 ...
- 获取本机网卡ip地址
import sys, os import socket, struct, fcntl import six import psutil def get_ip(iface="enp0s3&q ...
- linux入门系列15--文件传输之vsftp服务
前面的系列文章基本讲完了linux管理相关的基础知识,从本篇开始讲解centos7中服务程序的部署和配置,以便为外部提供各种服务. 日常工作和娱乐中,我们所需的各种资源都离不开网络以及各种服务,我们通 ...
- jq模糊匹配(qq:2798641729)
图灵学院--Java高级架构师-互联网企业级实战VIP课程(价值6380)(qq:1324981084) jq是一般程序员在前台开发的时候都会使用的技术,其中模糊匹配查询在动态添加标签的时候经常用到, ...
- 目前最全的Python的就业方向
Python是一门面向对象的编程语言,编译速度超快,从诞生到现在已经25个年头了.它具有丰富和强大的库,常被称为“胶水语言”,能够把用其他语言编写的各种模块(尤其是C/C++)很轻松地联结在一起.其特 ...
- 挂号平台首页开发(UI组件部分)
JQ插件模式开发UI组件 JQ插件开发方法: 1.$.extend() 扩展JQ(比较简单,功能略显不足) $.extend({ sayHello:function(){ console.log(&q ...
- spring cloud微服务快速教程之(十) gateway 服务网关
0.前言 gateway是spring的二代网关, 作为Netflix Zuul的替代者,是异步非阻塞网关 ,ZUUL2也是异步非阻塞的,但未纳入spring cloud整合计划 基于WebFlux ...