zoukankan      html  css  js  c++  java
  • spring-boot-plus后台快速开发脚手架之代码生成器使用(十)

    spring-boot-plus 代码生成 Generator

    代码生成内容

    • spring-boot-plus在mybatis-plus基础上,新增param/vo等模板
    • 拓展controller/service/mapper/xml,生成通用CRUD/分页方法
    • 代码生成模板:spring-boot-plus/src/test/resources/templates

    Purpose

    数据库新建表,即可生成后台CRUD/分页基础代码,还有swagger!

    官网地址:springboot.plus
    GITHUB:https://github.com/geekidea/spring-boot-plus
    GITEE:https://gitee.com/geekidea/spring-boot-plus
                     _                    _                 _                _
                    (_)                  | |               | |              | |
      ___ _ __  _ __ _ _ __   __ _ ______| |__   ___   ___ | |_ ______ _ __ | |_   _ ___
     / __| '_ | '__| | '_  / _` |______| '_  / _  / _ | __|______| '_ | | | | / __|
     \__  |_) | |  | | | | | (_| |      | |_) | (_) | (_) | |_       | |_) | | |_| \__ 
     |___/ .__/|_|  |_|_| |_|\__, |      |_.__/ \___/ \___/ \__|      | .__/|_|\__,_|___/
         | |                  __/ |                                   | |
         |_|                 |___/                                    |_|
    
          :: Spring Boot ::             (v2.1.6.RELEASE)
          :: Spring Boot Plus ::        (v1.0.0.RELEASE)
    

    代码生成步骤

    1. 创建数据库表,例如:sys_log

    注意:记得加上表注释,字段列注释,方便生成类注释、swagger注释

    -- ----------------------------
    -- Table structure for sys_log
    -- ----------------------------
    DROP TABLE IF EXISTS `sys_log`;
    CREATE TABLE `sys_log`  (
      `log_id` bigint(18) NOT NULL COMMENT '主键',
      `type` tinyint(1) NULL DEFAULT NULL COMMENT '类型',
      `content` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '内容',
      `create_id` bigint(18) NULL DEFAULT NULL COMMENT '创建人ID',
      `create_time` datetime(0) NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间',
      PRIMARY KEY (`log_id`) USING BTREE
    ) ENGINE = InnoDB CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统日志' ROW_FORMAT = Dynamic;
    
    1. 代码生成配置
    spring-boot-plus/src/test/java/io/geekidea/springbootplus/test/CodeGenerator.java
    

    代码生成器位置

    2.1 修改数据库连接配置

    private static final String USER_NAME = "root";
    private static final String PASSWORD = "rootroot";
    private static final String DRIVER_NAME = "com.mysql.jdbc.Driver";
    private static final String DRIVER_URL = "jdbc:mysql://localhost:3306/spring_boot_plus?useUnicode=true&characterEncoding=UTF-8&useSSL=false";
    

    2.2 修改模块、表、作者等配置

    // ############################ 配置部分 start ############################
    // 模块名称
    private static final String MODULE_NAME = "system";
    // 作者
    private static final String AUTHOR = "geekidea";
    // 生成的表名称
    private static final String TABLE_NAME = "sys_log";
    // 主键数据库列名称
    private static final String PK_ID_COLUMN_NAME = "log_id";
    // 代码生成策略 true:All/false:SIMPLE
    private static final boolean GENERATOR_STRATEGY = true;
    // 分页列表查询是否排序 true:有排序参数/false:无
    private static final boolean PAGE_LIST_ORDER = true;
    // ############################ 配置部分 end ############################
    
    • MODULE_NAME:模块名称,在目前项目上以单独的文件夹形式体现
    • AUTHOR:作者名称,在类的注释上体现
    • TABLE_NAME:表名称,当前需要生成的表名称,关联实体类等
    • PK_ID_COLUMN_NAME:主键列名称,默认是id,如果是其它名称,可在这里配置
    • GENERATOR_STRATEGY:代码生成策略 true:All/false:SIMPLE
    • PAGE_LIST_ORDER:分页列表查询是否排序 true:有排序参数/false:无
    1. 运行CodeGenerator.java

    3.1 控制台输出生成日志

    11:33:43.442 [main] DEBUG com.baomidou.mybatisplus.generator.AutoGenerator - ==========================准备生成文件...==========================
    11:33:44.167 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystementity]
    11:33:44.169 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemwebcontroller]
    11:33:44.170 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemservice]
    11:33:44.170 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemmapper]
    11:33:44.171 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 创建目录: [E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemserviceimpl]
    ...
    11:33:44.294 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/mapper.xml.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.308 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/mapper.xml.vm;  文件:E:githubspring-boot-plus/src/main/resources/mapper/system/SysLogMapper.xml
    11:33:44.313 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/queryParam.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.314 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/queryParam.java.vm;  文件:E:githubspring-boot-plus/src/main/java/io/geekidea/springbootplus/system/web/param/SysLogQueryParam.java
    11:33:44.332 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/queryVo.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.337 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/queryVo.java.vm;  文件:E:githubspring-boot-plus/src/main/java/io/geekidea/springbootplus/system/web/vo/SysLogQueryVo.java
    11:33:44.347 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/entity.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.357 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/entity.java.vm;  文件:E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystementitySysLog.java
    11:33:44.359 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/mapper.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.360 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/mapper.java.vm;  文件:E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemmapperSysLogMapper.java
    11:33:44.362 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/service.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.364 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/service.java.vm;  文件:E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemserviceSysLogService.java
    11:33:44.367 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/serviceImpl.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.369 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/serviceImpl.java.vm;  文件:E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemserviceimplSysLogServiceImpl.java
    11:33:44.373 [main] DEBUG org.apache.velocity - ResourceManager : found /templates/controller.java.vm with loader org.apache.velocity.runtime.resource.loader.ClasspathResourceLoader
    11:33:44.376 [main] DEBUG com.baomidou.mybatisplus.generator.engine.AbstractTemplateEngine - 模板:/templates/controller.java.vm;  文件:E:githubspring-boot-plus/src/main/javaiogeekideaspringbootplussystemwebcontrollerSysLogController.java
    11:33:44.376 [main] DEBUG com.baomidou.mybatisplus.generator.AutoGenerator - ==========================文件生成完成!!!==========================
    
    Process finished with exit code 0
    

    3.2 生成的模块和包结构

    ├─system                模块包
    │  ├─entity             实体类包
    │  ├─mapper             mybatis mapper接口包
    │  ├─service            服务接口包
    │  │  └─impl            服务实现包
    │  └─web                提供前端结果相关包
    │      ├─controller     控制器包
    │      ├─param          参数包
    │      └─vo             值对象,响应结果包
    

    3.3 生成的包及相关的类

    ├─system                                
    │  ├─entity                             
    │  │      SysLog.java                   实体类,已生成swagger注释
    │  ├─mapper                             
    │  │      SysLogMapper.java             mapper接口
    │  ├─service                            
    │  │  │  SysLogService.java             服务接口,已继承公共service
    │  │  └─impl                            
    │  │          SysLogServiceImpl.java    服务实现类,已继承公共service impl
    │  └─web                                
    │      ├─controller                     
    │      │      SysLogController.java     控制器类,已生成CRUD,分页controller方法,已生成swagger文档
    │      ├─param                                                
    │      │      SysLogQueryParam.java     请求参数类,用于条件分页查询等
    │      └─vo                             
    │              SysLogQueryVo.java       响应结果类,用于自定义查询响应结果等
    

    启动项目

    SpringBootPlusApplication.java
    
    2019-07-27 12:11:45.298  INFO 21856 --- [           main] o.s.b.w.embedded.tomcat.TomcatWebServer  : Tomcat started on port(s): 8888 (http) with context path ''
    2019-07-27 12:11:45.301  INFO 21856 --- [           main] i.g.s.SpringBootPlusApplication          : Started SpringBootPlusApplication in 9.66 seconds (JVM running for 10.988)
    2019-07-27 12:11:45.304  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : projectFinalName : spring-boot-plus
    2019-07-27 12:11:45.305  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : projectVersion : 1.0.0.RELEASE
    2019-07-27 12:11:45.305  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : profileActive : local
    2019-07-27 12:11:45.305  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : contextPath : /
    2019-07-27 12:11:45.305  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : port : 8888
    2019-07-27 12:11:45.308  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : home:http://192.168.1.168:8888/
    2019-07-27 12:11:45.308  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : docs:http://192.168.1.168:8888/docs
    2019-07-27 12:11:45.308  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : spring-boot-plus project start success...........
    2019-07-27 12:11:45.309  INFO 21856 --- [           main] i.g.s.util.PrintApplicationInfo          : 
     ____    __                    __        ____                                                   
    /  _` / \__                / \__    /  _`                                                 
     \,L\_  ,_    __     _ __  ,_    \,L\_  __  __    ___    ___     __    ____    ____  
     /_\__ \  /  /'__`  /\`'__  /    /_\__  / /   /'___ /'___ /'__` /',__  /',__ 
       / L   \_/ L.\_  /   \_     / L   \_ / \__// \__//  __//\__, `/\__, `
        `\____ \__ \__/.\_\ \_   \__     `\____ \____/ \____ \____ \____/\____//\____/
        /_____//__//__//_/ /_/   /__/     /_____//___/  /____//____//____//___/  /___/ 
    

    访问项目

    http://localhost:8888/swagger-ui.html

    或者访问本地ip

    http://192.168.xxx.xxx:8888/swagger-ui.html

    • 自动生成swagger CRUD、分页接口文档
      swagger
    1. add 添加接口swagger
      add 添加接口swagger

    2. delete 删除接口swagger
      delete 删除接口swagger

    3. getPageList 分页接口swagger
      getPageList 分页接口swagger

    4. info 详情接口swagger
      info 详情接口swagger

    5. update 修改接口swagger
      update 修改接口swagger

  • 相关阅读:
    centos 6.5安装erlang和RabbitMQ
    vert.x学习(八),用JDBCClient配合c3p0操作数据库
    vert.x学习(七),使用表单获取用户提交的数据
    vert.x学习(六),动态模板与静态文件的结合
    vert.x学习(五),用StaticHandler来处理静态文件
    函数-生成器、迭代器
    函数装饰器
    函数参数、作用域、高阶函数、递归函数、高阶函数
    深浅拷贝、集合set、函数、日志
    第一部分day5 文件操作
  • 原文地址:https://www.cnblogs.com/springbootplus/p/11334671.html
Copyright © 2011-2022 走看看