Zeus代码生成器是一款自动代码生成工具,旨在快速生成基础的CRUD代码,在此基础上也提供了一些高级功能,做到灵活配置,生成可扩展性强的代码。
后端是基于springboot、freemarker、mybatisplus实现
前端采用vue3、elementplus、electron技术
ZEUS官网
客户端在线下载
后端Gitee 仓库地址 | 前端Gitee 仓库地址
后端GitHub 仓库地址 | 前端GitHub 仓库地址
优势
1. 项目结构可视化,文件树、文件图形化的模板编辑,操作模板更加直观、简洁。
2. 使用Freemarker作为模板引擎,模板中支持Freemarker所有语法,系统提供强大的内置字典。模板操作更加灵活。
3. Zeus可以作为作为mysql、oracle客户端,直接连接内网数据库。
4. 脚本管理。取代Jenkins,轻量化快速更新打包项目。网页查看项目日志等功能。
5. 方便团队开发项目,统一代码风格,规范化代码接口。
客户端支持多开。同一个电脑可以打开多个客户端。可以分别登录管理员和普通用户的账号,管理员修改模板内容。普通用户生成代码。
下载客户端
客户端在线下载
客户端默认有两个用户
管理员 admin/admin
普通用户 test/123456
登录管理员账号,在项目管理处,可以查看 项目,进入项目管理查看目前已有的模板。
代码生成就是根据这些模板动态根据数据库反向生成代码
新建配置
登录普通用户账号
在配置管理处新建一条配置信息 具体查看6.2 普通用户新建配置
生成代码
在取码中心 选择配置、选择表 生成代码 具体查看6.3 普通用户生成代码
大功告成
打开配置管理 我们配置的文件路径,会看到生成的代码
管理员
团队技术leader,负责创建项目、组建项目人员、创建模板、管理用户、版本更新、脚本管理(更新打包)。
普通用户
普通开发人员,(前端后端都可以)通过配置中心配置项目路径和数据库地址。在取码中心快速生成代码、注入项目中
快捷键只在客户端有效
快捷键CTRL I
zeus代码生成器客户端可以动态切换请求的后台接口地址
快捷键CTRL ALT I
zeus代码生成器客户端,可打开浏览器控制台,查看接口信息
项目是由管理员定义,可以是前端项目、后端项目等任意形式,他具有项目名称、项目描述、是否公开、创建属性的属性。如果是非公开项目,可以给项目组建人员团队,指定人员能看到此项目。
数据字典是模板的高级配置。分为内置字典和自定义字典两种
内置字典是系统中自带的字典,在模板中用户可以直接使用字典值获取对应的数据。
内置字典的数据来源是,普通用户在配置中心配置的数据库连接,然后在取码中心选择的表。(表名、描述、字段列表)
用户通过在模板中使用内置字典可以完成基本单表CRUD操作
一级字典 | 二级字典 | 字典释义 | 示例 |
---|---|---|---|
${table_name} | 空 | 表名字 | model_user |
${tableDesc} | 空 | 表描述 | 用户表 |
${TableName} | 空 | 表名字首字母大写驼峰 | ModelUser |
${tableName} | 空 | 表名字首字母小写驼峰 | modelUser |
${FiledList} | filed_name | 字段名字 | user_name |
${FiledList} | filedDesc | 字段描述 | 用户名称 |
${FiledList} | FILEDNAME | 字段名字首字母大写驼峰 | UserName |
${FiledList} | filedName | 字段名字首字母小写驼峰 | userName |
${FiledList} | isKey | 是否主键 | Y/N |
${FiledList} | nullable | 是否非空 | Y/N |
${FiledList} | filedLen | 字段长度(数字) | 20 |
${FiledList} | scale | 精度(数字) | 2 |
${FiledList} | defaultValue | 默认值 | |
${FiledList} | realType | 真实字段类型 | varchar |
${FiledList} | javaType | 字段类型转JAVA类型 | String |
${FiledList} | xmlType | 字段类型转XML类型 | VARCHAR |
内置字典转化规则
字段类型转XML类型规则 | 字段类型转JAVA类型规则 |
---|---|
varchar ==> VARCHAR | varchar ==> String |
char ==> VARCHAR | double ==> Double |
text ==> LONGVARCHAR | char ==> String |
tinyint ==> TINYINT | text ==> String |
bigint ==> BIGINT | int ==> Integer |
int ==> INTEGER | tinyint ==> Integer |
numeric ==> DOUBLE | bigint ==> Long |
decimal ==> FLOAT | numeric ==> Double |
date ==> DATE | decimal ==> Float |
datetime ==> TIMESTAMP | date ==> Date |
datetime ==> TIMESTAMP |
自定义字典分为三类 字符串、数组、属性列表。
管理员可以在项目中定义该项目的内置字典。在模板中使用内置字典。类似于声明一个插槽。用户在生成代码的时候可以去灵活给插槽赋值。动态生成自己想要的代码。
分类 | 功能 |
---|---|
字符串 | 声明字符串类型的自定义字典,主要用来给模板中传如固定字符串。比如包名 |
数组 | 声明数组型字典,常见的主要用来控制后台的增删改查功能,或者前台的,按钮显示,增删改查功能 |
属性列表 | 属性列表是对内置字典中的FiledList的筛选。可以用来做前端查询条件、列表数据、编辑数据动态化 |
空间树是项目的目录结构,空间树,有文件和文件夹组成,文件是Freemarker模板。
用户通过构建自己项目空间树,动态生成具有此目录结构的代码到项目中来。
空间树的根节点就是项目的根目录。对应普通用户【配置中心】后台项目项目目录中的配置。
选中项目根节点,右键,即可新建文件或者文件夹。
然后,点击文件夹》右键》可以修改该文件夹,也可以新增该文件夹下的文件夹和文件
点击文件,在右侧填充对应的模板信息
填充好模板后,点击右上角提交代码按钮。即可保存模板
空间树目录要和实际项目目录保持一致
管理员可以通过用户管理功能创建系统用户
管理员可以通过版本更新实现客户端的快速更新迭代
版本更新分为线上更新和线下更新两种模式。
实现方式:
通过判断当前版本的版本号(数据库存储)和客户端的版本号(package.json的version属性)是否一致,如果不一致,就拉取最新的版本,下载到本地。重启客户端,完成客户端升级
1. 修改前端代码中的package.json中的version属性。
2. 前端代码打包 yarn run package:prod
3. 通过对前端代码进行打包,找到D:\workspace\workspace-zeus\zeus-view\dist_electron\win-ia32-unpacked\resources\app.asar文件。对此文件进行压缩,压缩成zip包,
4. 在【版本更新】处新建一个版本,版本号和version的版本号一致。上传刚才压缩的zip包
5. 重启客户端,自动拉去最新版本,完成更新
1. 修改前端代码中的package.json中的version属性。
2. 提交代码到git上
3. 执行【脚本管理】的 ‘生成器前端打包’脚本
4. 在【版本更新】处新建一个版本,版本号和version的版本号一致。选择线上。url固定填 http://39.101.173.227/zeus/app.zip
5. 重启客户端,自动拉去最新版本,完成更新
脚本文件 viewcode.sh
#!/bin/bash
#auth eric
#date 2021-07-14
#*********脚本入参#*********
appname=code
#Git源码位置
gitsrc=/home/egn/GitSpace/zeus-view
#Nginx位置
nginxsrc=/usr/local/nginx/html/zeus/
#*********脚本入参#*********
cd $gitsrc && git pull origin master && yarn run build:prod
mv -f $gitsrc/dist_electron/win-unpacked/resources/app.asar $nginxsrc
rm -rf $nginxsrc/*.zip
echo '删除历史包'
cd $nginxsrc
zip app.zip app.asar
echo '发布成功'
参考这个脚本,也可以做其他前端项目的自动打包
脚本文件 code.sh
#!/bin/bash
#auth eric
#date 2021-07-14
#*********脚本入参#*********
appname=code
#Git源码位置
gitsrc=/home/egn/GitSpace/zeus-server
#Docker脚本位置
dockersrc=/home/egn/DockerBuilder/$appname
#*********脚本入参#*********
cd $gitsrc && git pull origin master && mvn install -DskipTests
if [ $? -eq 0 ];
then
echo "maven build success "
else
echo -e '\033[31m[ error ] gradle build faild \033[0m' && exit 1
fi
\cp -f $gitsrc/target/*.jar $dockersrc
echo '第二步:查看是否有镜像'
cd $dockersrc
imageresult=$(docker images |grep $appname | wc -l)
if [ $imageresult -eq 0 ];
then
echo "不存在镜像,需要重新初始化鏡像";
docker build -t $appname .
docker run -d --name $appname -p 8003:8003 --restart always $appname
else
conid=$(docker ps |grep $appname |awk '{print $1}')
docker cp *.jar $conid:/$appname.jar
docker restart $conid
if [ $? -eq 0 ];
then
echo "发布成功!"
else
echo -e '\033[31m[ error ] 发布失败 \033[0m' && exit 1
fi
fi
参考此脚本,同理可以做后台项目自动打包部署
https://blog.csdn.net/qq_35921773/article/details/121694667
脚本管理核心是远程连接linux服务器,执行linux命令
用户可以通过该功能实现项目的远程打包、查看日志、服务重启……等操作
网页库是让用户快捷跳转项目常用网址的一个功能。管理员可以通过网页库新建该项目的所有网址,例如Gitlab、禅道、测试环境地址、原型地址……
普通用户在配置中心可以根据自己已有的项目,新建该项目的配置信息。
配置信息主要包含:选择项目、项目目录、配置名称、配置描述、数据库连接信息这些属性
用户可见的项目: 公开项目和私有项目用户在项目成员中
数据库连接信息: 客户端作为数据库连接工具,就像是Navicat一样获取当前数据的所有表。可以连接内网数据库
项目目录:生成的代码注入的目录。一般为项目根目录
注意:
使用zeus客户端生成代码会强制覆盖本地代码。所以在生成代码前,可以先通过配置详情功能选择要生成的文件
(前端待完善)
配置详情页面
数组类型字典,复选框勾选
属性列表型字典,表格复选框勾选
用户通过管理员分配的网页库可见权限,点击网页直接打开浏览器跳转到对应的网址
Tips: 客户端可以多开,可以同时打开两个客户端,一个登录管理员,一个登录普通用户。管理员实时编辑模板,普通用户实时生成代码。
管理员可以通过新增按钮创建项目,也可以直接通过复制操作,完全拷贝一个项目
在项目中构建自己的空间树、和模板。详情参考功能说明中的空间树介绍
普通用户在【配置管理】菜单中,新建配置
主要参考已有模板,Freemarker的所有语法都支持。
这里列举下常见语法
遍历数组
<#list FiledList as field>
private ${field.javaType} ${field.filedName};
#list>
字符串转数组
<#assign function_list=FunctionList?split(",") >
<#list function_list as function>
<#if (function == 'findPage')>
#if>
#list>
遍历数组获取下标
<#list FiledList as column>
<#if (column_index>0)>
<#if (column.javaType== 'String')>
if(StringUtils.isNotEmpty(body.getParameter().get${FiledList[0].FILEDNAME}())) queryWrapper.like("${column.filed_name}", body.getParameter().get${FiledList[0].FILEDNAME}());
#if>
<#if (column.javaType== 'Integer' || column.javaType== 'Double' || column.javaType== 'Float' || column.javaType== 'Long')>
if(body.getParameter().get${FiledList[0].FILEDNAME}() != null) queryWrapper.eq("${column.filed_name}", body.getParameter().get${FiledList[0].FILEDNAME}());
#if>
#if>
#list>
通过管理员登录系统,进入脚本管理,运行查看代码生成器日志脚本,查看模板报错信息。
zeus客户端软件权限
1. 桌面选择zeus客户端的logo
2. 右键》属性》打开文件所在位置》找到zeus.exe 以管理员权限运行
3. 桌面zeus快捷方式,右键》属性》高级》勾选 以管理员身份运行
切换【配置中心】代码。后台项目目录
尽量不要选C盘的,C盘权限不足会导致代码无法注入。
查看日志排查问题
接口问题排查
在客户端使用快捷键CTRL ALT I 可以打开控制台,查看生成代码接口,是否返回正常,如果是接口错误,大概率是模板错误
客户端问题排查
1. 桌面选择zeus客户端的logo
2. 右键》属性》打开文件所在位置
3. 复制当前路径
4. 使用管理员方式打开CMD,输入刚才输入的路径cd进去
5. 执行zeus.exe
6. 查看客户端日志