# 低代码开发平台-唛盟lcode后端 **Repository Path**: zhangmeng199711/mdp-lcode-backend ## Basic Information - **Project Name**: 低代码开发平台-唛盟lcode后端 - **Description**: 低代码开发平台-唛盟lcode旨在为企业开发业务系统提供一整套解决方案,唛盟具有高效率、低代码、功能丰富等特点。使用唛盟构建应用,您不用考虑多租户、登录、统一认证中心、权限、菜单管理、系统管理、公共组件、公共api、代码冗余、数据字典、图片库、文件库、智能表单、工作流、微服务互相调用、全局跟踪定位bug、多主键crud,复杂sql查询等各种问题,这些问题的解决方案都作为扩展功能内置 - **Primary Language**: Java - **License**: MIT - **Default Branch**: master - **Homepage**: http://111.230.141.161/lcode - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 1369 - **Created**: 2025-02-19 - **Last Updated**: 2025-02-19 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README
唛盟(mdp-lcode):多功能、高效率、低代码的前后端一体化、智能化的开发工具
>⚠️注意:本工程属于唛盟低代码平台的后端服务工程 ## 快速导航 - [唛盟-后端开发底座](https://gitee.com/maimengcloud/mdp-core) - [前端组件](https://gitee.com/maimengcloud/mdp-lcode-ui-web) - [后端服务](https://gitee.com/maimengcloud/mdp-lcode-backend) - [体验环境](http://111.230.141.161/lcode/m1/) 登陆界面上选择演示账号登陆或者直接扫码登陆,无须注册 - 相关教程b站上搜素[唛盟9哥教你撸前后端代码](https://www.bilibili.com/video/BV111421S72r/?spm_id_from=333.337.search-card.all.click&vd_source=93be23d03863773d50b81112985b9237) ## 📢 简介[唛盟低代码开发平台mdp-lcode](/) 本工程为唛盟低代码的后端工程 唛盟低代码开发平台简称唛盟或者mdp. 👉[唛盟-总体介绍](https://www.bilibili.com/video/BV111421S72r/?spm_id_from=333.337.search-card.all.click&vd_source=93be23d03863773d50b81112985b9237) 唛盟旨在为企业开发业务系统提供一整套解决方案,唛盟具有高效率、低代码、支持0代码、功能丰富等特点。企业可以在唛盟工程之上,加入更多其它业务功能;也可以以唛盟作为模板,创建新的工程,用于开发其它业务。使用唛盟构建应用,您不用考虑多租户、登录、统一认证中心、权限、菜单管理、系统管理、公共组件、公共api、代码冗余、数据字典、图片库、文件库、智能表单、工作流、微服务互相调用、全局跟踪定位bug、多主键crud,复杂sql查询等各种问题,这些问题的解决方案都作为扩展功能内置唛盟工程中了。 💪给你一个使用唛盟的理由:代码大量减少、开发so easy、前后端MIT协议、全部开源、永久免费 ## 📢 唛盟生态 💪唛盟生态遵循 “一个底座+N个专业子系统” 的架构,基于同一个底座的各个专业子系统可以任意组合形成一个大的业务系统。👉[聊聊唛盟生态1+n架构](https://www.bilibili.com/video/BV1BD421V7Bu/?spm_id_from=333.337.search-card.all.click&vd_source=93be23d03863773d50b81112985b9237) ### 底座 mdp-core [mdp-core](https://gitee.com/maimengcloud/mdp-core) ### N个专业子系统 以下专业子系统都是基于唛盟底座 + 唛盟低代码 搭建起来的 | 唛盟子系统 | 说明 | 版本 | |----------------------------------------------------------------------|------------------|--------| | [低代码、0代码](https://gitee.com/maimengcloud/mdp-lcode-ui-web)| 低代码、0代码框架 | 3.0.0 | | [账户、权限、组织管理](https://gitee.com/maimengcloud/mdp-lcode-backend/tree/master/mdp-sys)| 账户、权限、组织管理,支持多租户 | 3.0.0 | | [数据模型](https://gitee.com/maimengcloud/mdp-dm-backend/tree/master/mdp-dm-backend)|表结构设计、表数据增删改查等ddl、dml操作,在线执行sql等 | 3.0.0 | | [第三方支付登录等](https://gitee.com/maimengcloud/mdp-tpa-backend) | 微信支付、支付宝支付、paypal支付、第三方登录 | 3.0.0 | | [统一认证中心](https://gitee.com/maimengcloud/mdp-oauth2-backend) | 短信、微信、账号登录 | 3.0.0 | | [统一流程中心](https://gitee.com/maimengcloud/mdp-workflow-backend)| 审批、代办、设计流程、监控流程等 | 3.0.0 | | [短信](https://gitee.com/maimengcloud/mdp-sms-ui-web) | 群发消息 | 3.0.0 | | [代码生成器](https://gitee.com/maimengcloud/mdp-code-generator)| 自动生成前后端代码 | 3.0.0 | | [研发项目管理](https://gitee.com/maimengcloud/xm-ui-web)| 产品管理、需求管理、任务计划、迭代、测试、效能等 | 3.0.0 | | [即时通讯](https://gitee.com/maimengcloud/mdp-im-web) | 即时通讯、消息、聊天 | 3.0.0 | | [财务](https://gitee.com/maimengcloud/ac-core-ui-web)| 财务子系统,凭证、报销、会计记账、成本、结算 等 | 3.0.0 | | [协同办公](https://gitee.com/maimengcloud/oa-ui-web) | 办公用品、会议、车辆、资产、档案、用印、采购、绩效等功能 | 3.0.0 | ## 💪 内置功能、界面展示 本工程为唛盟低代码后端服务,功能列表以前端介绍为准,请点以下链接可查阅 [内置功能](https://gitee.com/maimengcloud/mdp-lcode-ui-web) ## ⚙ 技术栈 | 框架 | 说明 | 版本 | |----------------------------------------------------------------------|------------------|----------| | spring boot | spring boot 框架 | 2.6.11 | | mybatis plus | 数据库操作框架 | 3.5.3.1 | | spring security | 安全框架 | 2.1.7 | | jsqlparse | sql解析引擎 | 4.7+ | | swagger | 接口说明框架 | 2.2.8 | | logback | 日志框架 | 1.2.3 | | jexl13 | 表达式引擎 | 3.1 | | flowable | 流程引擎-可换 | 6.4.2 | | spring cloud | cloud框架-可换 | 2020.0.0 | | spring cloud consul | cloud框架-可换 | 1.10+ | | spring cloud consul | cloud框架-可换 | 1.10+ | | spring oauth2 | 统一认证中心-可换 | 5.2.2 | ## ⚙ 开发工具 | 插件名 | 功能 | |-------|-------------------------| | idea | java 开发工具 社区版、企业版都可 | | mysql | 数据库 mysql8以上,其它数据库请联系客服 | ## ⚙ 工程结构说明 | 子工程 | 功能 | |---------------------------|--------------------------| | mdp-arc-mate | 提供图片、文件存储压缩、预览、查询等功能 | | mdp-arc-pub | 提供公共分类、公共标签的增删改查服务 | | mdp-dm | 提供数据模型管理相关功能 | | mdp-form | 智能表单 | | mdp-lcode | 低代码的主体业务工程,低代码相关的功能 | | mdp-sys | 登录、组织结构、角色权限、菜单、人员、数据字典等管理功能 | | mdp-lcode-bootstrap | 打包部署工程 单体版 | | mdp-lcode-cloud-bootstrap | 打包部署工程 cloud版 | ## 💻 样例项目 - [低代码平台] (http://111.230.141.161/lcode) - [系统管理] (http://111.230.141.161/lcode) - [协同办公] (http://111.230.141.161/oa) - [项目管理] (http://111.230.141.161/xm) - [流程管理] (http://111.230.141.161/workflow) ## ⚙ 快速开始 ### 环境要求 数据库版本mysql8,jdk版本java-8-openjdk-amd64,部署时需要用到redis版本3.0.6 ### 开发 ```bash # 克隆开发底座项目 git clone https://gitee.com/maimengcloud/mdp-core.git # 安装开发底座依赖 mvn install # 克隆oauth2项目(非必须) git https://gitee.com/maimengcloud/mdp-oauth2-backend # 安装oauth2依赖 mvn install # 克隆cloud项目(非必须) git https://gitee.com/maimengcloud/mdp-cloud-backend # 安装cloud依赖 mvn install # 克隆lcode项目 git clone https://gitee.com/maimengcloud/mdp-lcode-backend.git # 安装lcode依赖 mvn install # 导入数据库脚本 # 1.创建wf库 如果不想用工作流,可忽略创建wf库,找到相关脚本,导入相关表到wf数据库中,如果已创建,该步忽略 [wf.sql](https://gitee.com/maimengcloud/mdp-workflow-backend/blob/master/sql/wf.sql) # 2.创建lcode库,导入相关脚本,如果已导入过,则忽略该步骤 [lcode_with_base_data.sql](./mdp-lcode/sql/lcode_with_base_data.sql) # 配置数据库链接链接(需要提前准备数据库) [application-dev.yml](./mdp-lcode/src/main/resources/application-dev.yml) # 启动服务 ⚠注意启动类放在test下面, 找到并运行[LcodeApplication.java](./mdp-lcode/src/test/java/com/mdp/LcodeApplication.java) ``` 访问端口 http://localhost:7014 ### 发布 #### 服务器的目录结构 假设工作空间为/home/m1/ ``` /hom/m1/ ├── start-service => 唛盟一键启停脚本存放目录 ├── config => spring boot的外置配置文件存放目录 ├── lib => jar包存放目录 ├── conf => 其它配置文件存放目录 ├── consul => consul安装目录 ├── logs => 唛盟日志存放目录 ├── backup-log => 日志备份存放目录 ├── arcfile => 唛盟内容素材上传下载访问的目录(素材存放目录) ├── bin => 一些公共脚本目录,如日志定时清理脚本、微服务注销脚本 ``` #### 构建 ```bash # 构建 在mdp-lcode-backend下执行 mvn instal ``` #### 发布及启停服务 ```bash # 部署 指部署jar包到nexus私服,如果企业没有nexus私服,则忽略此步骤 在mdp-lcode-backend下执行 mvn deploy # 手工发布到测试环境或者生产环境 如果是单体应用则拷贝并推送到服务器上[mdp-lcode-bootstrap-3.0.0-RELEASE.jar](./mdp-lcode-bootstrap/target/mdp-lcode-bootstrap-3.0.0-RELEASE.jar) 如果是微服务则拷贝并推送到服务器上[mdp-lcode-cloud-bootstrap-3.0.0-RELEASE.jar](./mdp-lcode-cloud-bootstrap/target/mdp-lcode-cloud-bootstrap-3.0.0-RELEASE.jar) # 启动应用(单体、cloud对jar包的引用不同,需要根据情况修改下脚本bootstrap-mdp-lcode-00.sh,默认是单体)初次部署把./start-service/bootstrap-mdp-lcode-00.sh拷贝到服务器上 sh bootstrap-mdp-lcode-00.sh ``` ### 接入统一认证中心 1.如果部署了统一认证中心,需要做配置更改。 统一认证中心相关的配置项: ```properties mdp.jwt.connect-oauth2-server=true|false 如果不需要对接统一认证中心,connect-oauth2-server设为false,则对jwt token的解析将采用HS256算法解密,默认为true mdp.oauth2.server.uri=统一认证中心的访问地址 如http://127.0.0.1:7000,如果是cloud环境下可以设置为http://oauth2server ``` ```yaml mdp: jwt: connect-oauth2-server: true oauth2: server: uri: http://127.0.0.1:7000 ``` 2.本地起的后端服务pom.xml文件需要引入[mdp-client-oauth2](https://gitee.com/maimengcloud/mdp-core/tree/master/mdp-clients/mdp-client-oauth2) 或者[mdp-client-oauth2-cloud](https://gitee.com/maimengcloud/mdp-core/tree/master/mdp-clients/mdp-client-oauth2-cloud) 单体应用下: ```xml