TienChin 渠道管理-工程创建

简介: 因为本文章主要围绕着项目开发进行,所以前言不做开头,直接上内容。

因为本文章主要围绕着项目开发进行,所以前言不做开头,直接上内容。


添加字段


我们的渠道表,我看到若依脚手架当中有一个是否删除的标志字段,所以我这里也添加一下:

ALTER TABLE `tienchin_channel`
    ADD COLUMN `del_flag` char(1) NULL DEFAULT '0' COMMENT '删除标志(0代表存在 2代表删除)' AFTER `update_time`;

新建模块


配置模块信息:



信息自己照着上方进行输入即可,具体的每一个选项,做这种项目不做过多介绍,因为并不是什么新的技术点,点击 Create。


channel 模块需要依赖一下 tienchin-common。


渠道管理最终的 pom.xml 内容:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>
    <parent>
        <groupId>top.it6666</groupId>
        <artifactId>tienchin</artifactId>
        <version>3.8.5</version>
    </parent>
    <artifactId>tienchin-channel</artifactId>
    <description>
        渠道管理模块
    </description>
    <dependencies>
        <!--
        通用工具
        -->
        <dependency>
            <groupId>top.it6666</groupId>
            <artifactId>tienchin-common</artifactId>
        </dependency>
    </dependencies>
</project>

定义版本号


父工程当中定义渠道管理模块版本号:

<!--
渠道管理
-->
<dependency>
    <groupId>top.it6666</groupId>
    <artifactId>tienchin-channel</artifactId>
    <version>${tienchin.version}</version>
</dependency>


注意点:

  • 渠道管理模块 version 的版本号要与当前父工程 pom.xml 内容中 tienchin.version 一致否则会报错



tienchin-admin 依赖 tienchin-channel:

<!--
渠道管理
-->
<dependency>
    <groupId>top.it6666</groupId>
    <artifactId>tienchin-channel</artifactId>
</dependency>


业务代码都写在 tienchin-channel 模块当中,admin 是 web 接口的入口,所以依赖调用一下我们写的业务类代码即可。


加入单元测试


在 tienchin-admin 加入依赖:

<!--
单元测试
-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-test</artifactId>
    <scope>test</scope>
</dependency>


更改 spring-boot 版本号为 2.5.13,并且将原先的版本号写在 dependencies 改造成定义在 properties 当中:

<spring-boot.version>2.5.13</spring-boot.version>


2105804-20230822004538565-1164283768.png

加入 MyBatisPlus 代码生成器


在父工程模块当中管理 MyBatisPlus 版本号:

<mybatis-plus-generator.version>3.5.3</mybatis-plus-generator.version>


<!--
MyBatisPlus 代码生成器
-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
    <version>${mybatis-plus-generator.version}</version>
</dependency>


引入依赖:

<!--
MyBatisPlus 代码生成器
-->
<dependency>
    <groupId>com.baomidou</groupId>
    <artifactId>mybatis-plus-generator</artifactId>
</dependency>
<!--
FreeMarker 是一个用 Java 编写的模板引擎。它不是用于生成 HTML 的 web 框架,而是一个用于生成文本输出的模板引擎。但在 web 开发中,它常常被用于生成 HTML。以下是 FreeMarker 的一些关键特点和用途:
1. **文本生成**:FreeMarker 主要是用来基于模板生成文本输出的。这可以是 HTML、XML、邮件正文,或者其他任何的文本格式。
2. **数据驱动**:你可以在模板中使用预定义的数据模型。当模板被处理时,FreeMarker 将这些数据与模板结合起来生成输出。
3. **灵活性**:FreeMarker 提供了丰富的内置函数和指令,允许开发者执行循环、条件判断和其他逻辑操作。
4. **与 web 框架集成**:虽然 FreeMarker 本身不是一个 web 框架,但它经常与 Java web 框架(如 Spring MVC)集成,作为视图技术来生成 HTML 页面。
5. **与 Java 集成**:FreeMarker 可以与 Java 对象轻松集成,这意味着你可以在模板中直接访问和使用 Java 对象的属性和方法。
6. **无依赖**:FreeMarker 不依赖于任何特定的 web 或应用服务器,因此可以在任何 Java 环境中使用。
7. **安全性**:FreeMarker 被设计为在安全受限的环境中运行,例如在服务器端为不受信任的用户生成内容。
总的来说,FreeMarker 是一个强大而灵活的模板引擎,适用于从简单的文本生成到复杂的 web 页面渲染等各种场景。
-->
<dependency>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-freemarker</artifactId>
</dependency>

本人在 MyBatisPlus 官网 copy 了一份代码,发现有问题,然后,我改造了一下,出现问题的代码效果如下图:



改造之后的代码,也是最终的代码,url, username, password 需要换成你们自己的:

/**
 * @author BNTang
 * @version 1.0
 * @description MyBatisPlus CRUD 代码生成器
 * @since 2023-17-20
 **/
@SpringBootTest
public class GenerateCode {
    @Test
    void generateChannel() {
        String path = "E:\\Desktop\\TienChin\\tienchin\\tienchin-channel\\src\\main";
        FastAutoGenerator.create(
                        "url",
                        "username",
                        "password"
                )
                .globalConfig(builder ->
                        builder
                                // 设置作者
                                .author("BNTang")
                                // 覆盖已生成文件
                                .fileOverride()
                                // 指定输出目录
                                .outputDir(path + "\\java"))
                .packageConfig(builder ->
                        builder
                                // 设置父包名
                                .parent("top.it6666")
                                // 设置父包模块名
                                .moduleName("channel")
                                // 设置mapperXml生成路径
                                .pathInfo(Collections.singletonMap(OutputFile.xml, path + "\\resources\\mapper")))
                .strategyConfig(builder ->
                        builder
                                // 设置需要生成的表名
                                .addInclude("tienchin_channel")
                                // 设置过滤表前缀
                                .addTablePrefix("tienchin_"))
                // 使用Freemarker引擎模板,默认的是Velocity引擎模板
                .templateEngine(new FreemarkerTemplateEngine())
                .execute();
    }
}

运行


点击单元测试的 run 按钮,就可以生成对应的模块文件夹如下图:



最后将 controller 移动到 tienchin-admin 模块当中的 top.it6666.web.controller.tienchin 下,本章节到此结束,主要就是新建了一下我们的渠道管理模块,下一节将进行业务代码的开发。

目录
相关文章
|
8月前
TienChin 活动管理-工程创建
TienChin 活动管理-工程创建
29 0
|
8月前
|
关系型数据库 MySQL
TienChin 渠道管理-渠道导入
TienChin 渠道管理-渠道导入
28 0
|
8月前
TienChin 渠道管理-渠道导出
TienChin 渠道管理-渠道导出
22 0
|
8月前
|
SQL
TienChin 渠道管理-渠道页面完善
TienChin 渠道管理-渠道页面完善
23 0
|
8月前
TienChin 活动管理-准备工作
TienChin 活动管理-准备工作
33 0
|
1天前
基于若依ruoyi-nbcio支持flowable流程角色,同时修改流转用户为username,流程启动做大调整(三)
基于若依ruoyi-nbcio支持flowable流程角色,同时修改流转用户为username,流程启动做大调整(三)
12 1
|
1天前
基于若依ruoyi-nbcio支持flowable流程角色,同时修改流转用户为username,流程启动做大调整(二)
基于若依ruoyi-nbcio支持flowable流程角色,同时修改流转用户为username,流程启动做大调整(二)
|
1天前
基于若依ruoyi-nbcio支持flowable流程角色,同时修改流转用户为username,流程启动做大调整(一)
基于若依ruoyi-nbcio支持flowable流程角色,同时修改流转用户为username,流程启动做大调整(一)
|
1天前
|
移动开发 前端开发 Java
基于jeecg-boot的flowable流程提供一种动态设置发起人部门负责人的方式
基于jeecg-boot的flowable流程提供一种动态设置发起人部门负责人的方式
|
8月前
TienChin 渠道管理-更新渠道接口开发
TienChin 渠道管理-更新渠道接口开发
35 0