克隆/下载
贡献代码
同步代码
取消
提示: 由于 Git 不支持空文件夾,创建文件夹后会生成空的 .keep 文件
Loading...
README
MIT

快速入门

在线体验

http://jqp.hyz792901324.com/

账号 admin

密码 1

登录后选择企业2,企业2目前配置了全量的权限

增删改查

流程

  1. 左侧菜单,系统管理->数据库表,新建,注意,建表会自动增加id列,自增主键,如果再增加id主键会报错
  2. 建完表后点击一键生成,会自动生成列表页面和表单页面,带有增删改查功能,并且会自动新建一个顶级菜单
  3. 左侧菜单,系统管理->页面管理,这是列表页面,根据表 test,找到刚才生成的页面,增加查询条件,调整显示字段,默认没有配置查询条件
  4. 左侧菜单,系统管理->表单管理,这是表单页面,根据表test找到刚才生成的表单,调整字段
  5. 左侧菜单,系统管理->菜单管理,调整菜单所属目录位置
  6. 左侧菜单,人员组织->企业管理,找到企业02,配置企业菜单,勾选刚才创建的菜单
  7. 右上角用户名下拉,退出登录,重新登录,就能看到功能了

截图

建表

image-20220405094029595

image-20220405094102710image-20220405094108564

image-20220405094130449

列表页面配置

image-20220405094206056

image-20220405094216485image-20220405094230538image-20220405094236868image-20220405095156123

image-20220405094301135

表单页面配置

image-20220405094331811image-20220405094344329image-20220405094412400image-20220405094532448

菜单配置

image-20220405095903249

配置企业菜单

image-20220405100030337image-20220405100052568

退出重进

image-20220405095935195

最终效果

安装

环境

  1. jdk8
  2. mysql8
  3. maven
  4. idea

克隆代码

git clone https://gitee.com/hyz79/jqp-admin.git

初始化数据库

项目 /db/ 目录下面有两个文件,任选其中一个恢复即可

  1. 数据库名jqp,编码utf8
  2. nb3文件,Navicat备份文件,复制到备份目录,右键还原,可以直接用Navicat还原
  3. -sql.zip文件,解压后导入到jqp
  4. 截图

image-20220405101426169

image-20220405101622769

详细讲解

rbac组织机构

  1. 总体来说就是 企业->人员-岗位-菜单按钮
  2. 菜单 sys_menu
  3. 用户 user 用户,用户分为普通用户和管理员,管理员可以拥有全部企业,全部企业菜单功能
  4. 企业 enterprise
  5. 企业管理员 enterprise_manager 企业管理员拥有此企业下全部菜单功能
  6. 企业菜单 enterprise_menu
  7. 岗位 position,岗位分固定岗位和自定义岗位,岗位编码全局唯一,岗位配置菜单是配置当前所在企业的菜单
  8. 企业岗位菜单 position_menu
  9. 企业人员 ,enterprise_user,创建企业用户会自动创建user表和enterprise_user关联,也可以关联其他企业用户
  10. 企业人员岗位 enterprise_user_position
  11. 权限定义 permission,字典为selfOrAll 的是自己/全部,字典为dept为部门级别数据权限
  12. position_permission 岗位数据权限
  13. dept_permission 部门数据权限
  14. 用户菜单逻辑,管理员取企业全部菜单,包含系统管理员和企业管理员
  15. 关联关系,用户->用户岗位->用户岗位菜单
  16. 数据权限,用户所在部门的数据权限和用户拥有全部岗位的数据权限和用户数据权限进行合并,取并集,最大范围
  17. 数据权限使用,在页面配置的查询sql里面 增加$service.permission('{code}','{field}') code为权限编码,field为当前查询对应的权限字段
  18. magicApi是表单前后置逻辑,返回字符串表示失败,返回null表示成功,最主要的写业务逻辑的地方,注意不要使用数据库增删改不要用magicApi内置的db接口,这样会导致无法记录字段日志

外键管理

主要用于做级联删除,删除主表后会自动删除关联的字表

菜单按钮配置

权限控制

在菜单管理里面有初始化按钮,点击后会自动的找到对应的列表页面,表单页面,下面的按钮,生成菜单按钮,并且吧按钮编号反写到对应的列表/表单按钮里面,如果按钮编号不配置,也就是不做按钮控制,任何人都能使用

image-20220405102528647

image-20220405102557419

image-20220405102617211

image-20220405102626169

公共url

没有关联菜单按钮的就是公共url,不用登录就能访问

image-20220405102715649

image-20220405102821053

按钮操作类型

例子

image-20220405103412463

按钮配置的规则

这是禁用规则,就是什么条件下,这按钮不能用,能得到的参数是当前行的数据字段,也可以是隐藏的字段,注意不需要携带$符号

image-20220405103925959

弹出表单

操作配置填写表单编号,会自动携带id字段到表单里面

弹出iframe

自定义的页面,无法通过配置出来的,可以用这种方式,参数携带可以有多个

弹出页面

操作配置用逗号隔开的字符串,第一个是列表页面编号,第二个是关联的字段,主表的id,关联字表对应的字段

请求

ajax请求,可以有get/post请求,点击会自动有二次确认的弹出提示,可以在按钮配置提示的内容,默认是 格式 确认{按钮名称}操作吗?

  1. get请求: get:/xxx 可以携带参数 ${字段名}
  2. post请求: post:/xxx 携带json格式的requestBody

打开新窗口

浏览器打开新的窗口页面,可以配置多个参数例如:

http://www.baidu.com?id=${id}&name=${abcName}

数据权限配置

整体思路

权限定义

  1. 看自己/全部的数据权限
  2. 看本部门/本部门及子部门/负责部门/负责部门及子部门/全部部门
  3. 其他权限,可以选择一个页面/字典/sql语句查询出一个列表,在这个列表里面做多选/单选/树结构选择

权限配置,可以在岗位,部门,人员上面配置数据权限,使用的时候会取当前登录人所能关联到的对应配置权限的最大集合

权限使用,在列表页面里面的sql拼接权限,

使用 $service.permission('dept','c.dept_id') ,其中,dept是权限编码,c.dept_id是在本列表页面中的部门字段

java代码在 TemplateService 里面,这个是在TemplateUtil.getValue里面注入进去的

image-20220405110555264

例子,截图

image-20220405105745953

image-20220405105810264

image-20220405105826292

image-20220405105833178

image-20220405105844808

image-20220405105854524

image-20220405105907924

image-20220405110030022

image-20220405110058622

image-20220405110132422

image-20220405110214294

列表配置

查询sql

注意,这里面用了TemplateUtil.getValue方法,会自动的注入TemplateService这个,提供数据权限配置,可以做额外扩展

image-20220405110840907

js配置暂时没有用上

页面宽度在页面关联里面会讲到

名称字段,值字段,用于提供给下拉框组件,选择器组件,或者是数据权限等里面使用到的

查询结果配置

配置完sql后,在查询结果配置点击刷新,会自动根据查询结果的字段,匹配对应的类型,中文

宽度,可以调整这个列的宽度

特殊字段类型

日期类型

日期类型必须要配置格式

字典类型

字典类型格式化,配置为字典编号

其他类型

会自动展示

查询条件配置

字段

名称和结果里面的字段一致,比如user_code,不能写成userCode,

操作类型

多值的话,后台是逗号隔开的字符串,

包含是模糊匹配

数据类型

数据字典

需要在格式化里面配置字典编号

选择器

需要在格式化里面配置列表页面的编号

日期类型

需要配置日期格式化

图片/文件类型

可以配置为字符串,然后在组件里面选择图片,文件,可以配置单选多选

其他类型

配置单选/多选,配置组件类似

配置按钮

参考详细讲解->按钮配置规则

页面关联

对于列表页左右布局,可以在基本信息,配置页面宽度,12是100%,6是50%,关联页面是12-主页面宽度

多个子页面用tab分开

注意注意:查询条件里面有一个是否关联字段,如果为是的情况下,在没有选择主表的时候默认值是-1,也就是必须要有主表才能查询/新增,新增的时候也要注意配置按钮禁用

例如,字典和字典明细

image-20220405112909505

image-20220405112933622

image-20220405112946460

image-20220405113014571

image-20220405113038349

表单配置

基本信息

  1. 初始化接口,新建/编辑会根据id查询数据,带到表单里面,如果默认的不满足条件,可以增加初始化sql,会自动的把查询的sql里面字段,按照字段名赋值给表单,可以有多个sql,用分号 ; 隔开,也可以自定义
  2. 保存接口,有默认的,通用保存接口,不满足可以自定义,公共的保存在CommonController里面
  3. 字段宽度,栅格布局,12为100%一行,6为50%,这是默认的每个字段宽度,每个字段上也可以单独配置
  4. 前置接口,保存前的校验,这是和magic-api链接的地方,返回值不是空的情况下就表示校验失败,不会保存,且提示失败原因,是magic-api返回的字符串
  5. 后置接口,在默认保存后调用的,也在CommonController里面,会将默认保存和后置接口,封装到同一个事物里面,保证事务一致性
  6. 前置接口和后置接口都可以有多个,用换行符隔开,参数可以查看CommonController里面源码
  7. image-20220405114047670

组件

有一种特殊的场景,只有一个关联字段,比如用户关联岗位,去选择多个岗位,

可以参考

image-20220405114920831

image-20220405114959228

字段配置

实际上和列表的字段配置很类似,增加重复校验

image-20220405114202818

其中多字段联合唯一,将多个字段用逗号隔开,配置到校验重复配置里面

sql校验唯一,写一段sql,放到校验重复配置里面,具体的代码也是参考CommonController的保存方法

字段默认值

除了配置固定值之外,还能配置其他信息,比如当前用户,当前时间,自动生成订单号等等,参考TemplateService,配置实例,$service.serial(序号编码),

默认数据表更新和插入时间,只需要定义相应的名字即可,不需要额外操作:field名称设置为updatedAt 为数据库更新时间;名称为createdAt为数据表插入时间

image-20220405115235669

image-20220405115451061

image-20220405115529527

页面关联

和列表页面关联类似,实例:

image-20220405114412154

image-20220405114428323

image-20220405114450381

image-20220405114508134

工作流配置

整体设计

  1. 就是针对某一个业务单据,进行状态流转

  2. 在定义工作流的时候,需要配置,那个表,对应的状态字段,查看表单

  3. 在设计流程的时候需要在每个节点配置当前状态值

  4. 在每个流转设置下一个状态值

  5. 流转代表审批时候的按钮

  6. 初始化sql,也就给这个流程实例的上下文,默认会带入当前业务单据实例

  7. 可以配置任务前置/后置接口,这是每个任务前置后置都会执行的,可以根据参数判断当前属于那个节点

  8. 前置接口做校验,后置接口做额外保存

  9. 参考

    image-20220405120911244

image-20220405121005436

image-20220405121017200

image-20220405121036301

image-20220405121051517

image-20220405121105064

image-20220405121330171

image-20220405121401006

image-20220405121423803

image-20220405121443250

image-20220405121456549

定时任务

配置接口,就是magic-api,如果返回非空字符串,就是任务执行失败,

image-20220405115701649

动态任务

动态任务可以理解为延时一次性任务

这是在给定一个时间,只执行一次的任务,在代码里面提供创建任务的方法,DynamicTaskService.save

使用场景,下单后多久未支付,取消订单

操作日志

记录那张表,那个字段在什么时候从什么值变成什么值

注意事项

操作日志是基于jdbcService的增删改查做的,如果用magic-api的增删改查,就无法记录

配置需要记录的表

image-20220405121627548

查看操作日志

image-20220405121703146

image-20220405121714248

配置查看日志按钮

image-20220405121757775

image-20220405121812085

图表配置

图表配置主要包含数据配置和展现配置

展现配置参考echarts,尤其是数据集这块

https://echarts.apache.org/handbook/zh/concepts/dataset/

不用通用的options的原因是,用page的话,可以自定义布局,这块可以参考amis文档

https://aisuda.bce.baidu.com/amis/

数据配置是sql语句,可以配置多个sql,每个sql返回一个list<key,value>格式结果集,按照顺序命名为data0,data1...

在展现配置里面引用${data0},${data1}

菜单配置为

/admin/chart/{code}

参考截图

image.png

image.png

image.png

关键目录

后台java部分

activity

工作流

common

文件上传下载,图片验证码,操作日志

db

封装基础的增删改查

page

页面/表单配置

rbac

人员组织

util

工具类

前端部分

activity-web

工作流相关

admin

光年后台管理,菜单框架,登录等

amis

百度amis

json/sys

最基础的三个页面

  1. page.js 列表页面配置
  2. form.js 表单配置
  3. tableInfo.js 数据库表

ui-json-template

前端用到的一些通用模板

image-20220405122614040

使用技术

magic-api

https://www.ssssssss.org/

activity

hu-tools

https://www.hutool.cn/

springboot2

velocity

https://www.cnblogs.com/xiohao/p/5788932.html

百度amis

https://aisuda.bce.baidu.com/

联系方式

个人qq

792901324

微信

hyz792901324

qq群

550662264

MIT License Copyright (c) 2022 hyz Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions: The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software. THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

简介

基于百度amis,springboot2.6,magic-api开发的一套低代码后台管理平台,从建表开始,配置页面,表单,复杂的关联关系,实现了功能权限,数据权限,工作流,sass运营商模式,其中大部分页面(90%以上)都是通过配置出来的 展开 收起
Java
MIT
取消

发行版

暂无发行版

贡献者

全部

近期动态

不能加载更多了
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化