package freemarker.constant;public class TemplateConstant {//实体类模板public static final String entityTemplate = "templates/Entity.ftl";//Mapper模板public static final String mapperTemplate = "templates/Mapper.ftl";//Mapper映射文件模版public static final String mapperXmlTemplate = "templates/MapperXml.ftl";//service模版public static final String serviceTemplate = "templates/Service.ftl";//service实现类模版public static final String serviceImplTemplate = "templates/ServiceImpl.ftl";//controller模版public static final String controllerTemplate = "templates/Controller.ftl";//vo模版public static final String entityVoTemplate = "templates/EntityVo.ftl";//dto模版public static final String entityDtoTemplate = "templates/EntityDto.ftl";//pom模版public static final String pomTemplate = "templates/pom.ftl";//application.yml模版public static final String applicationTemplate = "templates/application.ftl";
}
(1)DbUtil数据库工具类
package freemarker.util;import freemarker.param.ColumnClass;
import freemarker.param.TableClass;
import lombok.Getter;
import lombok.Setter;import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;/*** 数据库工具类*/
@Setter
@Getter
public class DbUtil {//数据库连接地址private String url = "jdbc:mysql://localhost:3306/heima_leadnews_wemedia?useSSL=false&nullCatalogMeansCurrent=true&serverTimezone=UTC";//数据库用户名private String username = "root";//数据库密码private String password = "123456";//数据库驱动private String driver = "com.mysql.jdbc.Driver";//数据库名称private String dbName = null;private Connection connection =null;/*** 获取jdbc链接* @return* @throws Exception*/public Connection getConnection() throws Exception{Properties pro = new Properties();pro.setProperty("user", username);pro.setProperty("password", password);pro.put("useInformationSchema", "true");//获取mysql表注释//pro.setProperty("remarksReporting","true");//获取oracle表注释Class.forName(driver);connection = DriverManager.getConnection(url, pro);return connection;}/*** 获取当前数据库下的所有表名称及注释* @return* @throws Exception*/public List getAllTables() throws Exception {List list = new ArrayList<>();//获取链接Connection conn = getConnection();//获取元数据DatabaseMetaData metaData = conn.getMetaData();//获取所有的数据库表信息ResultSet rs = metaData.getTables(dbName!=null?dbName:conn.getCatalog(), "%", "%", new String[]{"TABLE"});while (rs.next()) {TableClass tableClass = new TableClass();tableClass.setTableName(rs.getString(3));tableClass.setTableComment(rs.getString(5));list.add(tableClass);}return list;}/*** 获取某张表的所有列* @param tableName* @return* @throws Exception*/public List getAllColumns(String tableName) throws Exception {List list = new ArrayList<>();//获取链接Connection conn = getConnection();//获取元数据DatabaseMetaData metaData = conn.getMetaData();//获取所有的数据库某张表所有列信息ResultSet rs = metaData.getColumns(dbName!=null?dbName:conn.getCatalog(), "%", tableName,"%");while(rs.next()) {ColumnClass columnClass = new ColumnClass();columnClass.setColumnName(rs.getString("COLUMN_NAME"));columnClass.setColumnType(rs.getString("TYPE_NAME"));columnClass.setColumnComment(rs.getString("REMARKS"));columnClass.setChangeColumnName(StrUtil.changeColumnStr(rs.getString("COLUMN_NAME")));list.add(columnClass);}return list;}/*** 关闭链接*/public void closeConnection(){try {connection.close();} catch (SQLException e) {e.printStackTrace();}};}
(2)字符串处理工具类
package freemarker.util;/*** 字符串处理工具类*/
public class StrUtil {/*** 去掉下划线转驼峰 user_name -> userName* @param str* @return*/public static String changeColumnStr(String str) {String name = str;if (name.indexOf("_") > 0 && name.length() != name.indexOf("_") + 1) {int lengthPlace = name.indexOf("_");name = name.replaceFirst("_", "");String s = name.substring(lengthPlace, lengthPlace + 1);s = s.toUpperCase();str = name.substring(0, lengthPlace) + s + name.substring(lengthPlace + 1);} else {return str;}return changeColumnStr(str);}/*** 去掉下划线转驼峰 tb_user -> TbUser* @param str* @return*/public static String changeTableStr(String str) {String s = changeColumnStr(str);return s.substring(0,1).toUpperCase()+s.substring(1);}
}
(3)FreeMarker模版工具类
package freemarker.util;import freemarker.cache.FileTemplateLoader;
import freemarker.cache.NullCacheStorage;
import freemarker.template.Configuration;
import freemarker.template.Template;
import freemarker.template.TemplateExceptionHandler;import java.io.File;
import java.io.IOException;
import java.io.UnsupportedEncodingException;/*** FreeMarker模版工具类*/
public class FreeMarkerTemplateUtils {private FreeMarkerTemplateUtils(){}private static final Configuration CONFIGURATION = new Configuration(Configuration.VERSION_2_3_22);static{//ClassTemplateLoader方式:需要将模版放在FreeMarkerTemplateUtils类所在的包,加载模版时会从该包下加载//CONFIGURATION.setTemplateLoader(new ClassTemplateLoader(FreeMarkerTemplateUtils.class,""));try {String path = java.net.URLDecoder.decode(FreeMarkerTemplateUtils.class.getClassLoader().getResource("").getPath(),"utf-8");//FileTemplateLoader方式:需要将模版放置在classpath目录下 目录有中文也可以CONFIGURATION.setTemplateLoader(new FileTemplateLoader(new File(path)));} catch (UnsupportedEncodingException e) {e.printStackTrace();} catch (IOException e) {e.printStackTrace();}CONFIGURATION.setDefaultEncoding("UTF-8");CONFIGURATION.setTemplateExceptionHandler(TemplateExceptionHandler.RETHROW_HANDLER);CONFIGURATION.setCacheStorage(NullCacheStorage.INSTANCE);}public static Template getTemplate(String templateName) throws IOException {try {return CONFIGURATION.getTemplate(templateName);} catch (IOException e) {throw e;}}public static void clearCache() {CONFIGURATION.clearTemplateCache();}
}
(1)表实体类
package freemarker.param;import lombok.Data;@Data
public class TableClass {/*** 表名 tb_user**/private String tableName;/*** 表注释**/private String tableComment;}
(2)列实体类
package freemarker.param;import lombok.Data;@Data
public class ColumnClass {/*** 数据库字段名称 user_name**/private String columnName;/*** 数据库字段类型**/private String columnType;/*** 数据库字段首字母小写且去掉下划线字符串 userName**/private String changeColumnName;/*** 数据库字段注释**/private String columnComment;}
(3)模版相关参数类
package freemarker.param;import lombok.Data;
import org.apache.commons.lang3.StringUtils;import java.text.SimpleDateFormat;
import java.util.Date;@Data
public class TemplatePathParam {private String currentDate = new SimpleDateFormat("yyyy/MM/dd").format(new Date());//包名 com.itheima.userprivate String packageName;//代码生成路径 D:\\pathprivate String basePath;//项目名称 英文 比如itheima-userprivate String projectName;//作者private String author ;//实体类生成的绝对路径private String entityPath;//vo实体类生成的绝对路径private String entityVoPath;//Dto实体类生成的绝对路径private String entityDtoPath;//mapper生成绝对路径private String mapperPath;//mapper映射文件生成的绝对路径private String mapperXmlPath;//service接口生成的绝对路径private String servicePath;//service实现类生成的绝对路径private String serviceImplPath;//controller生成的绝对路径private String controllerPath;//pom文件生成的绝对路径private String pomPath;//application.yml文件生成的绝对路径private String applicationYmlPath;public TemplatePathParam(String packageName, String basePath, String projectName, String author) {if(StringUtils.isBlank(packageName)|| StringUtils.isBlank(basePath)|| StringUtils.isBlank(author)|| StringUtils.isBlank(projectName)){throw new RuntimeException("参数不能为空");}this.packageName = packageName;this.basePath = basePath;this.author = author;this.projectName = projectName;String[] split = packageName.split("\\.");// D:\\path\\itheima-user\\src\\main\\java\\com\\itheima\\userString javaModelPath = basePath+"\\"+projectName+"\\src\\main\\java\\"+split[0]+"\\"+split[1]+"\\"+split[2];String xmlModelPath = basePath+"\\"+projectName+"\\src\\main\\resources\\"+split[0]+"\\"+split[1]+"\\"+split[2];this.setEntityPath(javaModelPath+"\\entity");this.setMapperPath(javaModelPath+"\\mapper");this.setMapperXmlPath(xmlModelPath+"\\mapper");this.setServicePath(javaModelPath+"\\service");this.setServiceImplPath(javaModelPath+"\\service\\impl");this.setControllerPath(javaModelPath+"\\http\\controller");this.setEntityVoPath(javaModelPath+"\\http\\vo");this.setEntityDtoPath(javaModelPath+"\\http\\dto");this.setEntityDtoPath(javaModelPath+"\\http\\dto");this.setPomPath(basePath+"\\"+projectName);this.setApplicationYmlPath(basePath+"\\"+projectName+"\\src\\main\\resources");}}
package freemarker;import freemarker.constant.TemplateConstant;
import freemarker.param.ColumnClass;
import freemarker.param.TableClass;
import freemarker.param.TemplatePathParam;
import freemarker.template.Template;
import freemarker.util.DbUtil;
import freemarker.util.FreeMarkerTemplateUtils;
import freemarker.util.StrUtil;
import org.apache.commons.lang3.StringUtils;import java.io.*;
import java.util.HashMap;
import java.util.List;
import java.util.Map;/*** 代码生成器入口*/
public class CodeGenerateUtils {private TemplatePathParam templatePathParam = null;public static void main(String[] args) throws Exception{CodeGenerateUtils codeGenerateUtils = new CodeGenerateUtils();codeGenerateUtils.generate();System.out.println("============ 全部生成完成! =============");}public void generate() throws Exception{/*** 参数1:报名* 参数2:生成代码的基础路径* 参数3:项目名称* 参数4:作者*/templatePathParam = new TemplatePathParam("com.itheima.wemedia","D:\\heima\\技术文章\\代码","itheima-wemedia","kdm");//数据库相关DbUtil dbUtil = new DbUtil();//获取所有表List allTable = dbUtil.getAllTables();for (TableClass tableClass : allTable) {//表名String table = tableClass.getTableName();//获取所有列List allColumns = dbUtil.getAllColumns(table);System.out.println("-------- 正在生成 " + table+" 表相关文件------");//生成实体类System.out.println("生成实体类");generateEntityFile(tableClass, allColumns);//生成MapperSystem.out.println("生成Mapper");generateMapperFile(tableClass, allColumns);//生成Mapper.xmlSystem.out.println("生成Mapper映射文件");generateMapperXmlFile(tableClass, allColumns);//生成service接口System.out.println("生成service接口");generateServiceFile(tableClass, allColumns);//生成service实现类System.out.println("生成service实现类");generateServiceImplFile(tableClass, allColumns);//生成Controller层文件System.out.println("生成Controller层文件");generateControllerFile(tableClass, allColumns);//生成vo类System.out.println("生成vo类");generateEntityVoFile(tableClass, allColumns);//生成dto类System.out.println("生成dto类");generateEntityDtoFile(tableClass, allColumns);//生成pom文件System.out.println("生成pom文件");generatePomFile(tableClass, allColumns);//生成application.yml文件System.out.println("生成application.yml文件");generateApplicationYmlFile(tableClass, allColumns);}dbUtil.closeConnection();}/*** 生成实体文件*/private void generateEntityFile(TableClass tableClass, List allColumns) throws Exception{String suffix = ".java";String filePath = templatePathParam.getEntityPath();String file = templatePathParam.getEntityPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap.put("model_column",allColumns);dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.entityTemplate, filePath, file, dataMap);}/*** 生成mapper文件*/private void generateMapperFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "Mapper.java";String filePath = templatePathParam.getMapperPath();String file = templatePathParam.getMapperPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.mapperTemplate, filePath, file, dataMap);}/*** 生成xml映射文件*/private void generateMapperXmlFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "Mapper.xml";String filePath = templatePathParam.getMapperXmlPath();String file = templatePathParam.getMapperXmlPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.mapperXmlTemplate, filePath, file, dataMap);}/*** 生成业务接口层*/private void generateServiceFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "Service.java";String filePath = templatePathParam.getServicePath();String file = templatePathParam.getServicePath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.serviceTemplate, filePath, file, dataMap);}/*** 生成业务实现层*/private void generateServiceImplFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "ServiceImpl.java";String filePath = templatePathParam.getServiceImplPath();String file = templatePathParam.getServiceImplPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.serviceImplTemplate, filePath, file, dataMap);}/*** 生成控制层*/private void generateControllerFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "Controller.java";String filePath = templatePathParam.getControllerPath();String file = templatePathParam.getControllerPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.controllerTemplate, filePath, file, dataMap);}/*** 生成Vo类*/private void generateEntityVoFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "Vo.java";String filePath = templatePathParam.getEntityVoPath();String file = templatePathParam.getEntityVoPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap.put("model_column",allColumns);dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.entityVoTemplate, filePath, file, dataMap);}/*** 生成Dto类*/private void generateEntityDtoFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "Dto.java";String filePath = templatePathParam.getEntityDtoPath();String file = templatePathParam.getEntityDtoPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;Map dataMap = new HashMap();dataMap.put("model_column",allColumns);dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.entityDtoTemplate, filePath, file, dataMap);}/*** 生成Pom文件*/private void generatePomFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "pom.xml";String filePath = templatePathParam.getPomPath();String file = templatePathParam.getPomPath() + "\\" + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.pomTemplate, filePath, file, dataMap);}/*** 生成application.yml文件*/private void generateApplicationYmlFile(TableClass tableClass, List allColumns) throws Exception{String suffix = "application.yml";String filePath = templatePathParam.getApplicationYmlPath();String file = templatePathParam.getApplicationYmlPath() + "\\" + suffix;Map dataMap = new HashMap();dataMap = getCommonModel(dataMap, tableClass);generateFileByTemplate(TemplateConstant.applicationTemplate, filePath, file, dataMap);}/*** 模版通用参数* @param dataMap 模型map* @param tableClass 表名和表注释参数* @return*/public Map getCommonModel(Map dataMap, TableClass tableClass){dataMap.put("table_name", StrUtil.changeTableStr(tableClass.getTableName()));//TbUserdataMap.put("table_name_small",StrUtil.changeColumnStr(tableClass.getTableName()));//tbUserdataMap.put("table",tableClass.getTableName());//tb_userdataMap.put("author",templatePathParam.getAuthor());dataMap.put("date",templatePathParam.getCurrentDate());dataMap.put("package_name",templatePathParam.getPackageName());dataMap.put("project_name",templatePathParam.getProjectName());dataMap.put("table_annotation", StringUtils.isNotBlank(tableClass.getTableComment()) ? tableClass.getTableComment() : null);return dataMap;}/*** 静态化方法* @param templateName 模版名称* @param filePathParam 文件所在目录 绝对路径* @param fileParam 文件 绝对路径* @param dataMap 数据模型* @throws Exception*/private void generateFileByTemplate(final String templateName,String filePathParam,String fileParam,Map dataMap) throws Exception{Template template = FreeMarkerTemplateUtils.getTemplate(templateName);System.out.println(fileParam);//文件夹不存在创建文件夹File filePath = new File(filePathParam);if (!filePath.exists() && !filePath.isDirectory()){filePath.mkdirs();}//文件不存在创建文件夹File file = new File(fileParam);if(!file.exists()){try {file.createNewFile();} catch (IOException e) {e.printStackTrace();}}FileOutputStream fos = new FileOutputStream(file);Writer out = new BufferedWriter(new OutputStreamWriter(fos, "utf-8"),10240);template.process(dataMap,out);}}
在 resources/templates 目录下创建模版类
package ${package_name}.entity;import com.baomidou.mybatisplus.annotation.TableField;
import com.baomidou.mybatisplus.annotation.TableId;
import com.baomidou.mybatisplus.annotation.TableName;
import lombok.Data;
import lombok.ToString;
import java.util.Date;
import java.math.BigDecimal;
import com.fasterxml.jackson.annotation.JsonFormat;import java.io.Serializable;/**
* 描述:<#if table_annotation??>${table_annotation}模型#if>
* @author ${author}
* @date ${date}
*/
@Data
@ToString(callSuper = true)
@TableName("${table}")
public class ${table_name} implements Serializable {
<#if model_column?exists><#list model_column as model>/*** ${model.columnComment!}*/<#if (model.columnType = 'BIGINT' && model.columnName = 'id')>@TableId("${model.columnName?uncap_first}")private Long ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'BIGINT' && model.columnName != 'id')>@TableField("${model.columnName?uncap_first}")private Long ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'INT' || model.columnType = 'INT UNSIGNED' || model.columnType = 'TINYINT' || model.columnType = 'TINYINT UNSIGNED')>@TableField("${model.columnName?uncap_first}")private Integer ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'DECIMAL')>@TableField("${model.columnName?uncap_first}")private BigDecimal ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'VARCHAR' || model.columnType = 'TEXT' || model.columnType = 'CHAR')>@TableField("${model.columnName?uncap_first}")private String ${model.changeColumnName?uncap_first};#if><#if model.columnType = 'TIMESTAMP' || model.columnType = 'YEAR' || model.columnType = 'DATE' || model.columnType = 'DATETIME' >@TableField("${model.columnName?uncap_first}")@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss", timezone="GMT+8")private Date ${model.changeColumnName?uncap_first};#if><#if (model.columnType != 'BIGINT'&& model.columnType != 'INT'&& model.columnType != 'DECIMAL'&& model.columnType != 'VARCHAR'&& model.columnType != 'TEXT'&& model.columnType != 'CHAR'&& model.columnType != 'TIMESTAMP'&& model.columnType != 'YEAR'&& model.columnType != 'DATE'&& model.columnType != 'DATETIME'&& model.columnType != 'INT UNSIGNED'&& model.columnType != 'TINYINT'&& model.columnType != 'TINYINT UNSIGNED')>@TableField("${model.columnName?uncap_first}")private MISS ${model.changeColumnName?uncap_first};#if>#list>
#if>}
package ${package_name}.mapper;import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import ${package_name}.entity.${table_name};
import org.apache.ibatis.annotations.Mapper;
/**
* 描述:<#if table_annotation??>${table_annotation}数据库连接层#if>
* @author ${author}
* @date ${date}
*/
@Mapper
public interface ${table_name}Mapper extends BaseMapper<${table_name}> {}
package ${package_name}.service;import ${package_name}.entity.${table_name};
import com.baomidou.mybatisplus.extension.service.IService;/**
* 描述:<#if table_annotation??>${table_annotation}服务实现层接口#if>
* @author ${author}
* @date ${date}
*/
public interface ${table_name}Service extends IService<${table_name}>{}
package ${package_name}.service.impl;import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import ${package_name}.entity.${table_name};
import ${package_name}.service.${table_name}Service;
import ${package_name}.mapper.${table_name}Mapper;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;/**
* 描述:<#if table_annotation??>${table_annotation}服务实现层#if>
* @author ${author}
* @date ${date}
*/
@Slf4j
@Service
public class ${table_name}ServiceImpl extends ServiceImpl<${table_name}Mapper, ${table_name}> implements ${table_name}Service{}
package ${package_name}.http.controller;import org.springframework.web.bind.annotation.*;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.beans.BeanUtils;
import org.springframework.validation.annotation.Validated;
import ${package_name}.entity.${table_name};
import ${package_name}.service.${table_name}Service;
import ${package_name}.http.vo.${table_name}Vo;
import ${package_name}.http.dto.${table_name}Dto;import java.util.List;/**
* 描述:<#if table_annotation??>${table_annotation}控制层#if>
* @author ${author}
* @date ${date}
*/
@RestController
@RequestMapping("/${table_name_small}")
public class ${table_name}Controller {@Autowiredprivate ${table_name}Service ${table_name_small}Service;/*** 查询所有*/@GetMappingpublic List<${table_name}> list(){return ${table_name_small}Service.list();}/*** 查询一个*/@GetMapping("/{id}")public ${table_name} get(@PathVariable Long id){return ${table_name_small}Service.getById(id);}/*** 新增*/@PostMappingpublic boolean save(@Validated @RequestBody ${table_name}Dto ${table_name_small}Dto){${table_name} ${table_name_small} = new ${table_name}();BeanUtils.copyProperties(${table_name_small}Dto, ${table_name_small});return ${table_name_small}Service.save(${table_name_small});}/*** 修改*/@PutMappingpublic boolean update(@Validated @RequestBody ${table_name}Dto ${table_name_small}Dto){${table_name} ${table_name_small} = new ${table_name}();BeanUtils.copyProperties(${table_name_small}Dto, ${table_name_small});return ${table_name_small}Service.updateById(${table_name_small});}/*** 删除* @param id* @return 是否成功*/@DeleteMapping("/{id}")public boolean del(@PathVariable Long id){return ${table_name_small}Service.removeById(id);}
}
package ${package_name}.http.vo;import java.io.Serializable;
import java.util.Date;
import lombok.Data;
import lombok.ToString;
import java.math.BigDecimal;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;/**
* 描述:<#if table_annotation??>${table_annotation}模型#if>Vo类
* @author ${author}
* @date ${date}
*/
@Data
@ToString(callSuper = true)
public class ${table_name}Vo implements Serializable {
<#if model_column?exists><#list model_column as model><#if (model.columnType = 'BIGINT' && model.columnName = 'id')>@JsonSerialize(using = ToStringSerializer.class)private Long ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'BIGINT' && model.columnName != 'id')>private Long ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'INT' || model.columnType = 'INT UNSIGNED' || model.columnType = 'TINYINT')>private Integer ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'DECIMAL')>private BigDecimal ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'VARCHAR' || model.columnType = 'TEXT' || model.columnType = 'CHAR')>private String ${model.changeColumnName?uncap_first};#if><#if model.columnType = 'TIMESTAMP' || model.columnType = 'YEAR' || model.columnType = 'DATE' || model.columnType = 'DATETIME' >@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss", timezone="GMT+8")private Date ${model.changeColumnName?uncap_first};#if><#if (model.columnType != 'BIGINT' && model.columnType != 'INT' && model.columnType != 'VARCHAR' && model.columnType != 'DECIMAL' && model.columnType != 'TEXT' && model.columnType != 'CHAR' && model.columnType != 'TIMESTAMP' && model.columnType != 'YEAR' && model.columnType != 'DATE' && model.columnType != 'DATETIME' && model.columnType != 'INT UNSIGNED')>private MISS ${model.changeColumnName?uncap_first};#if>#list>
#if>
}
package ${package_name}.http.dto;import java.io.Serializable;
import java.util.Date;
import lombok.Data;
import lombok.ToString;
import java.math.BigDecimal;
import com.fasterxml.jackson.annotation.JsonFormat;
import com.fasterxml.jackson.databind.annotation.JsonSerialize;
import com.fasterxml.jackson.databind.ser.std.ToStringSerializer;
import com.fasterxml.jackson.annotation.JsonFormat;/**
* 描述:<#if table_annotation??>${table_annotation}模型#if>Dto类
* @author ${author}
* @date ${date}
*/
@Data
@ToString(callSuper = true)
public class ${table_name}Dto implements Serializable {
<#if model_column?exists><#list model_column as model><#if (model.columnType = 'BIGINT' && model.columnName = 'id')>@JsonSerialize(using = ToStringSerializer.class)private Long ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'BIGINT' && model.columnName != 'id')>private Long ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'INT' || model.columnType = 'INT UNSIGNED' || model.columnType = 'TINYINT')>private Integer ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'DECIMAL')>private BigDecimal ${model.changeColumnName?uncap_first};#if><#if (model.columnType = 'VARCHAR' || model.columnType = 'TEXT' || model.columnType = 'CHAR')>private String ${model.changeColumnName?uncap_first};#if><#if model.columnType = 'TIMESTAMP' || model.columnType = 'YEAR' || model.columnType = 'DATE' || model.columnType = 'DATETIME' >@JsonFormat(pattern="yyyy-MM-dd HH:mm:ss", timezone="GMT+8")private Date ${model.changeColumnName?uncap_first};#if><#if (model.columnType != 'BIGINT' && model.columnType != 'INT' && model.columnType != 'VARCHAR' && model.columnType != 'DECIMAL' && model.columnType != 'TEXT' && model.columnType != 'CHAR' && model.columnType != 'TIMESTAMP' && model.columnType != 'YEAR' && model.columnType != 'DATE' && model.columnType != 'DATETIME' && model.columnType != 'INT UNSIGNED')>private MISS ${model.changeColumnName?uncap_first};#if>#list>
#if>
}
4.0.0 ${package_name} ${project_name} 1.0-SNAPSHOT org.springframework.boot spring-boot-starter-parent 2.3.9.RELEASE UTF-8 UTF-8 11 11 2.3.9.RELEASE 1.18.8 5.1.46 3.3.1 org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-test com.baomidou mybatis-plus-boot-starter ${r"${mybatis-plus.version}"} mysql mysql-connector-java ${r"${mysql.version}"} org.projectlombok lombok ${r"${lombok.version}"} org.apache.commons commons-lang3 3.10
server:port: ${r"${port:8888}"}
spring:application:name: ${project_name}
运行代码生成器入口类 CodeGenerateUtils
输出日志如下
D:\app\devs\Java\jdk-11\bin\java.exe "-javaagent:D:\app\devs\JetBrains\IntelliJ IDEA 2018.2.4\lib\idea_rt.jar=60577:D:\app\devs\JetBrains\IntelliJ IDEA 2018.2.4\bin" -Dfile.encoding=UTF-8 -classpath D:\heima\技术文章\itheima-code\target\classes;D:\app\devs\apache-maven-3.3.9\maven_repository\org\freemarker\freemarker\2.3.23\freemarker-2.3.23.jar;D:\app\devs\apache-maven-3.3.9\maven_repository\mysql\mysql-connector-java\5.1.47\mysql-connector-java-5.1.47.jar;D:\app\devs\apache-maven-3.3.9\maven_repository\org\projectlombok\lombok\1.18.8\lombok-1.18.8.jar;D:\app\devs\apache-maven-3.3.9\maven_repository\org\apache\commons\commons-lang3\3.10\commons-lang3-3.10.jar freemarker.CodeGenerateUtils
-------- 正在生成 undo_log 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\UndoLog.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\UndoLogMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\UndoLogMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\UndoLogService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\UndoLogServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\UndoLogController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\UndoLogVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\UndoLogDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_channel 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmChannel.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmChannelMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmChannelMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmChannelService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmChannelServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmChannelController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmChannelVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmChannelDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_fans_statistics 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmFansStatistics.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmFansStatisticsMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmFansStatisticsMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmFansStatisticsService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmFansStatisticsServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmFansStatisticsController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmFansStatisticsVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmFansStatisticsDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_material 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmMaterial.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmMaterialMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmMaterialMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmMaterialService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmMaterialServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmMaterialController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmMaterialVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmMaterialDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_news 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmNews.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmNewsMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmNewsMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmNewsService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmNewsServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmNewsController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmNewsVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmNewsDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_news_material 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmNewsMaterial.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmNewsMaterialMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmNewsMaterialMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmNewsMaterialService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmNewsMaterialServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmNewsMaterialController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmNewsMaterialVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmNewsMaterialDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_news_statistics 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmNewsStatistics.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmNewsStatisticsMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmNewsStatisticsMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmNewsStatisticsService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmNewsStatisticsServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmNewsStatisticsController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmNewsStatisticsVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmNewsStatisticsDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_sensitive 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmSensitive.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmSensitiveMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmSensitiveMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmSensitiveService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmSensitiveServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmSensitiveController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmSensitiveVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmSensitiveDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
-------- 正在生成 wm_user 表相关文件------
生成实体类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\entity\WmUser.java
生成Mapper
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\mapper\WmUserMapper.java
生成Mapper映射文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\com\itheima\wemedia\mapper\WmUserMapper.xml
生成service接口
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\WmUserService.java
生成service实现类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\service\impl\WmUserServiceImpl.java
生成Controller层文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\controller\WmUserController.java
生成vo类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\vo\WmUserVo.java
生成dto类
D:\heima\技术文章\代码\itheima-wemedia\src\main\java\com\itheima\wemedia\http\dto\WmUserDto.java
生成pom文件
D:\heima\技术文章\代码\itheima-wemedia\pom.xml
生成application.yml文件
D:\heima\技术文章\代码\itheima-wemedia\src\main\resources\application.yml
============ 全部生成完成! =============
在idea中点击 File > open 打开 D:\heima\技术文章\代码\itheima-wemedia