如何自定义代码生成器(下)

news2025/1/10 11:38:50

4.2 编码

4.2.1 常量类

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";
}

4.2.2 工具类

(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<TableClass> getAllTables() throws Exception {
        List<TableClass> 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<ColumnClass> getAllColumns(String tableName) throws Exception {
        List<ColumnClass> 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();
    }
}

4.2.3 实体类

(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.user
    private String packageName;
    //代码生成路径 D:\\path
    private String basePath;
    //项目名称  英文  比如itheima-user
    private 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\\user
        String 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");
    }

}

4.2.4 代码生成器入口类

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<TableClass> allTable = dbUtil.getAllTables();
        for (TableClass tableClass : allTable) {
            //表名
            String table = tableClass.getTableName();
            //获取所有列
            List<ColumnClass> allColumns = dbUtil.getAllColumns(table);
            System.out.println("-------- 正在生成  " + table+"  表相关文件------");
            //生成实体类
            System.out.println("生成实体类");
            generateEntityFile(tableClass, allColumns);

            //生成Mapper
            System.out.println("生成Mapper");
            generateMapperFile(tableClass, allColumns);
            
            //生成Mapper.xml
            System.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<ColumnClass> allColumns) throws Exception{
        String suffix = ".java";
        String filePath = templatePathParam.getEntityPath();
        String file = templatePathParam.getEntityPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap.put("model_column",allColumns);
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.entityTemplate, filePath, file, dataMap);
    }

    /**
     * 生成mapper文件
     */
    private void generateMapperFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "Mapper.java";
        String filePath = templatePathParam.getMapperPath();
        String file = templatePathParam.getMapperPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);

        generateFileByTemplate(TemplateConstant.mapperTemplate, filePath, file, dataMap);
    }
    /**
     * 生成xml映射文件
     */
    private void generateMapperXmlFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "Mapper.xml";
        String filePath = templatePathParam.getMapperXmlPath();
        String file = templatePathParam.getMapperXmlPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.mapperXmlTemplate, filePath, file, dataMap);
    }
    /**
     * 生成业务接口层
     */
    private void generateServiceFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "Service.java";
        String filePath = templatePathParam.getServicePath();
        String file = templatePathParam.getServicePath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.serviceTemplate, filePath, file, dataMap);
    }
    /**
     * 生成业务实现层
     */
    private void generateServiceImplFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "ServiceImpl.java";
        String filePath = templatePathParam.getServiceImplPath();
        String file = templatePathParam.getServiceImplPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.serviceImplTemplate, filePath, file, dataMap);
    }
    /**
     * 生成控制层
     */
    private void generateControllerFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "Controller.java";
        String filePath = templatePathParam.getControllerPath();
        String file = templatePathParam.getControllerPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.controllerTemplate, filePath, file, dataMap);
    }
    /**
     * 生成Vo类
     */
    private void generateEntityVoFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "Vo.java";
        String filePath = templatePathParam.getEntityVoPath();
        String file = templatePathParam.getEntityVoPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap.put("model_column",allColumns);
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.entityVoTemplate, filePath, file, dataMap);
    }
    /**
     * 生成Dto类
     */
    private void generateEntityDtoFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "Dto.java";
        String filePath = templatePathParam.getEntityDtoPath();
        String file = templatePathParam.getEntityDtoPath() + "\\"+ StrUtil.changeTableStr(tableClass.getTableName()) + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap.put("model_column",allColumns);
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.entityDtoTemplate, filePath, file, dataMap);
    }
    /**
     * 生成Pom文件
     */
    private void generatePomFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "pom.xml";
        String filePath = templatePathParam.getPomPath();
        String file = templatePathParam.getPomPath() + "\\" + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.pomTemplate, filePath, file, dataMap);
    }
    /**
     * 生成application.yml文件
     */
    private void generateApplicationYmlFile(TableClass tableClass, List<ColumnClass> allColumns) throws Exception{
        String suffix = "application.yml";
        String filePath = templatePathParam.getApplicationYmlPath();
        String file = templatePathParam.getApplicationYmlPath() + "\\" + suffix;

        Map<String,Object> dataMap = new HashMap<String,Object>();
        dataMap = getCommonModel(dataMap, tableClass);
        generateFileByTemplate(TemplateConstant.applicationTemplate, filePath, file, dataMap);
    }

    /**
     * 模版通用参数
     * @param dataMap 模型map
     * @param tableClass 表名和表注释参数
     * @return
     */
    public Map<String,Object> getCommonModel(Map<String,Object> dataMap, TableClass tableClass){
        dataMap.put("table_name", StrUtil.changeTableStr(tableClass.getTableName()));//TbUser
        dataMap.put("table_name_small",StrUtil.changeColumnStr(tableClass.getTableName()));//tbUser
        dataMap.put("table",tableClass.getTableName());//tb_user
        dataMap.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<String,Object> 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);
    }

}

5 制作通用模版

在 resources/templates 目录下创建模版类

5.1 实体类模版

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>

}

5.2 Mapper模版

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}> {

}

5.3 Mapper映射文件模版

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="${package_name}.mapper.${table_name}Mapper">

</mapper>

5.4 Service接口模版

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}>{

}

5.5 Service实现类模版

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{

}

5.6 Controller模版

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 {

	@Autowired
	private ${table_name}Service ${table_name_small}Service;

	/**
	 * 查询所有
	 */
	@GetMapping
	public 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);
	}

	/**
	 * 新增
	 */
	@PostMapping
	public 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});
	}

	/**
	 * 修改
	 */
	@PutMapping
	public 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);
	}
}

5.7 实体类Vo模版

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>
}

5.8 实体类Dto模版

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>
}

5.9 pom文件模版

<?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>${package_name}</groupId>
    <artifactId>${project_name}</artifactId>
    <version>1.0-SNAPSHOT</version>

    <!-- 继承Spring boot工程 -->
    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.3.9.RELEASE</version>
    </parent>
    <properties>
        <!-- 项目源码及编译输出的编码 -->
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <!-- 项目编译JDK版本 -->
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
        <!-- 依赖包版本管理 -->
        <spring.boot.version>2.3.9.RELEASE</spring.boot.version>
        <lombok.version>1.18.8</lombok.version>
        <mysql.version>5.1.46</mysql.version>
        <mybatis-plus.version>3.3.1</mybatis-plus.version>
    </properties>


    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
        <dependency>
            <groupId>com.baomidou</groupId>
            <artifactId>mybatis-plus-boot-starter</artifactId>
            <version>${r"${mybatis-plus.version}"}</version>
        </dependency>
        <dependency>
            <groupId>mysql</groupId>
            <artifactId>mysql-connector-java</artifactId>
            <version>${r"${mysql.version}"}</version>
        </dependency>
        <dependency>
            <groupId>org.projectlombok</groupId>
            <artifactId>lombok</artifactId>
            <version>${r"${lombok.version}"}</version>
        </dependency>
        <dependency>
            <groupId>org.apache.commons</groupId>
            <artifactId>commons-lang3</artifactId>
            <version>3.10</version>
        </dependency>
    </dependencies>

</project>

5.10 application.yml文件模版

server:
  port: ${r"${port:8888}"}
spring:
  application:
    name: ${project_name}

6 测试

运行代码生成器入口类 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

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/11409.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

k8s教程(12)-pod 全自动调度

文章目录01 引言02 Deployment & RC2.1 功能2.2 举例03 文末01 引言 声明&#xff1a;本文为《Kubernetes权威指南&#xff1a;从Docker到Kubernetes实践全接触&#xff08;第5版&#xff09;》的读书笔记 在前面的博客《k8s教程&#xff08;11&#xff09;-pod调度概述》&…

【2022秋线上作业-第5次-第11-13周】选择题

2-1 下列线索二叉树中&#xff08;用虚线表示线索&#xff09;&#xff0c;符合后序线索树定义的是&#xff1a;B 解析&#xff1a; 后序遍历dbca 所以d前驱为null&#xff0c;d后继为b&#xff0c;c没有孩子&#xff0c;前驱为b&#xff0c;后继为a&#xff0c;a有左右孩子。…

拓扑排序板子练习

目录 一、前言 二、拓扑排序板子 三、题目&#xff1a;拓扑顺序 1、上链接 2、基本思路 3、代码 &#xff08;1&#xff09;C&#xff08;AC&#xff09; &#xff08;2&#xff09;python&#xff08;AC&#xff09; 四、题目&#xff1a;可达性统计 1、上链接 2、…

C++线程创建的方式和使用

进程与线程 进程 简单的可以认为是一个程序执行的过程。进程就是活跃的程序&#xff0c;在内存中运行&#xff0c;占用系统的资源。线程 线程也叫轻量级进程&#xff0c;通常一个进程包含若干个线程。线程可以利用进程所拥有的资源。在引入线程的操作系统中&#xff0c;通常都…

关于软件文档写作

关于软件文档写作目录概述需求&#xff1a;设计思路实现思路分析1.业务逻辑2.代码表达3.形式归纳4.方式和工具参考资料和推荐阅读Survive by day and develop by night. talk for import biz , show your perfect code,full busy&#xff0c;skip hardness,make a better resul…

JS模块化—CJSAMDCMDES6-前端面试知识点查漏补缺

本文从以时间为轴从以下几个方面进行总结JS模块化。从无模块化 > IIFE > CJS > AMD > CMD > ES6 > webpack这几个阶段进行分析。 历史 幼年期&#xff1a;无模块化 方式 需要在页面中加载不同的js&#xff0c;用于动画&#xff0c;组件&#xff0c;格式化…

【软件测试】一个边界值事故,领导leader心里苦季度奖金没了还被罚3K......

目录&#xff1a;导读前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09;前言 项目组长&#xff1…

java类的练习--下面给出一个根据雇员类型利用多态性完成

java类的练习–下面给出一个根据雇员类型利用多态性完成… 题目 ​ 下面给出一个根据雇员类型利用多态性完成工资单计算的程序。定义一个类Employee作为超类&#xff0c;Employee的子类有Boss&#xff08;每星期发给他固定工资&#xff0c;而不计工作时间&#xff09;、Piece…

顶级“Redis学习笔记”,缓存雪崩+击穿+穿透+集群+分布式锁,NB了

如果你是一位后端工程师&#xff0c;面试时八成会被问到 Redis&#xff0c;特别是那些大型互联网公司&#xff0c;不仅要求面试者能简单使用 Redis&#xff0c;还要深入理解其底层实现原理&#xff0c;具备解决常见问题的能力。可以说&#xff0c;熟练使用 Redis 就是后端工程师…

超140支爆款B站恰饭,2022年B站双11战报来了!

- 导语 从0到3.06亿月活&#xff0c;从“与世无争”到今天手持高粘性、高活跃的用户参战双十一&#xff0c;在B站的品牌们有了更成熟的营销模式。 2022年双十一已经落下帷幕&#xff0c;在B站全面拥抱双十一的火热氛围下&#xff0c;有哪些品牌做到了声量、销量双丰收&#x…

【毕业设计】深度学习人脸表情识别系统 - python

文章目录0 前言1 技术介绍1.1 技术概括1.2 目前表情识别实现技术2 实现效果3 深度学习表情识别实现过程3.1 网络架构3.2 数据3.3 实现流程3.4 部分实现代码4 最后0 前言 &#x1f525; Hi&#xff0c;大家好&#xff0c;这里是丹成学长的毕设系列文章&#xff01; &#x1f5…

基于 BERT 实现的情感分析(文本分类)----概念与应用

文章目录基于 BERT 的情感分析(文本分类)基本概念理解简便的编码方式: One-Hot 编码突破: Word2Vec编码方式新的开始: Attention 与 Transformer 模型四方来降: 超一流预处理模型 BERT 诞生BERT 实现情感分析数据预处理并创建数据集定义网络模型定义训练函数与评估函数设置损失…

AVL树的插入(C++实现)

1. 概念 AVL树&#xff08;Adelson-Velsky and Landis Tree&#xff09;于1962年被提出&#xff0c;是计算机科学中最早被发明的平衡二叉查找树。AVL树得名于它的发明者G. M. Adelson-Velsky和Evgenii Landis。 在AVL树中&#xff0c;任一节点对应的两棵子树的最大高度差为1&…

大一新生HTML期末作业 个人网页王嘉尔明星介绍网页设计与制作

&#x1f389;精彩专栏推荐&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb;&#x1f447;&#x1f3fb; ✍️ 作者简介: 一个热爱把逻辑思维转变为代码的技术博主 &#x1f482; 作者主页: 【主页——&#x1f680;获取更多优质源码】 &#x1f393; web前端期末大作业…

领悟《信号与系统》之 信号与系统的描述-上节

信号与系统的描述-上节一、信号分类1. 一维信号和多维信号2. 确定信号和随机信号3. 连续时间信号和离散时间信号4. 周期信号和非周期信号5. 能量信号和功率信号二、常见工程信号1. 正弦信号2. 指数信号3. 取样信号4. 单位矩形脉冲信号5. 符号函数在真实的物理世界中&#xff0c…

Redis的优惠券秒杀问题(五)全局唯一ID 以及 秒杀下单

Redis的优惠券秒杀问题&#xff08;五&#xff09;全局唯一ID 以及 秒杀下单 关于优惠秒杀问题的Redis实现章节总览 全局唯一ID 场景分析 不能用自增的原因 id的规律性太明显 受单表数据量的限制 全局唯一ID的条件 全局唯一ID的Redis实现 代码实现 单元测试 其它…

【FPGA】FPGA实现SPI协议读写FLASH(一)----- M25P16操作概述

文章目录一、FLASH介绍&#xff08;M25P16&#xff09;1、M25P16概述2、SPI模式3、存储结构4、指令集5、时间参数二、M25P16工作原理三、M25P16指令操作1、页编程 (PP)2、扇区擦除和整块擦除 (SE and BE)3、写使能 (WREN)4、读ID&#xff08;RDID&#xff09;5、读状态寄存器&a…

使用c#将aj-report桌面化:1.winform嵌入浏览器

说到底,aj-report是个工具,我想大多数人还是想快速使用它来创建一个可以展示的工具。通过之前的章节,你应该可以制作自己的报表页面了,下面我们来看看怎么把aj-report包装成一个桌面能够运行的软件。 当然作为扩展开发,受开源协议限制,我们不能大规模修改aj-report的源代…

【毕业设计】深度学习图像修复算法研究与实现 - python

文章目录1 前言2 什么是图像内容填充修复3 原理分析3.1 第一步&#xff1a;将图像理解为一个概率分布的样本3.2 补全图像3.3 快速生成假图像3.4 生成对抗网络(Generative Adversarial Net, GAN) 的架构3.5 使用G(z)生成伪图像4 在Tensorflow上构建DCGANs5 最后1 前言 &#x1…

PC_OS中断/中断屏蔽字

文章目录程序中断&#x1f383;中断概念中断功能(作用)中断请求中断源中断分类外中断非屏蔽中断和可屏蔽中断陷入(内中断)硬件中断和软件中断关系整理&#x1f388;中断判优&#x1f388;中断优先级CPU响应中断的条件外中断实现思路&#x1f388;中断隐指令 及其工作①关中断②…