基于 magic-api 搭建自己的低代码平台
一、前言
2021 开年“低代码”成了热门话题,各大云厂商都在加码。作为普通企业的我们是否有也可以深度定制一套自己的“低代码”平台呢?
二、云厂商的低代码平台
阿里推出了易搭,通过简单的拖拽、配置,即可完成业务应用的搭建。旨在为广大中小企业提供一套低成本的企业应用搭建解决方案。应用无缝植入钉钉企业工作台,随时随地、高效协同。
腾讯则是推出了微搭,通过行业化模板、拖放式组件和可视化配置快速构建多端应用(小程序、H5 应用、Web 应用等),打通了小程序、云函数。
三、搭建我们自己的低代码平台?!
回到前言中的问题,我们是否可以基于开源项目来快速搭建我们自己的低代码平台呢?答案是肯定的,目前已经有很多非常不错的开源项目,apijson、dataway 还有后面我要重点介绍的 magic-api 都是非常不错的低代码开源项目。下面大家请跟着我一起来看看今天我要推荐的三个低代码开源项目:百度 amis、h5-Dooring 和 magic-api。
3.1百度 amis(前端)
百度 amis 是一套前端低代码框架,通过 JSON 配置就能生成各种后台页面,极大减少开发成本,甚至可以不需要了解前端。
3.2 h5-Dooring(前端)
h5-Dooring,让 H5 制作像搭积木一样简单, 轻松搭建 H5 页面, H5 网站, PC 端网站, 可视化设计。
H5 页面拖拽生成:
新建数字大屏:
数字大屏效果:
更多请查看官网http://h5.dooring.cn
3.3 magic-api(后端)
magic-api 是一个基于 Java 的接口快速开发框架,编写接口将通过 magic-api 提供的 UI 界面完成,自动映射为 HTTP 接口,无需定义 Controller、Service、Dao、Mapper、XML、VO 等 Java 对象即可完成常见的 HTTP API 接口开发。
在线开发调试 UI:
四、magic-api 搭建
自 magic-api 在开源中国开源,笔者一直在关注此项目。magic-api 搭建比较简单,跟着官方仓库快速开始即可。
4.1 加入依赖
<!-- 以 spring-boot-starter 的方式引用 -->
<dependency>
<groupId>org.ssssssss</groupId>
<artifactId>magic-api-spring-boot-starter</artifactId>
<version>1.0.1</version>
</dependency>
4.2 添加配置
server.port=9999
#配置 web 页面入口
magic-api.web=/magic/web
#配置文件存储位置。当以 classpath 开头时,为只读模式
magic-api.resource.location=/data/magic-api
4.3 效果
4.4 添加接口
点击执行就可以看到效果,这里不做展示,magic-api 官方做了大量的各种各样的功能演示,大家可以去体验体验。地址:http://140.143.210.90:9999/magic/web/index.html
4.5 magic-api 核心之 magic-script
magic-api 底层使用的是作者(小东)自研的 magic-script 来执行脚本,他是一个语法类似 js 的 JVM 脚本语言。作者开发很多好用的功能, 其中的linq功能就是非常🐂💨的一个。
示例:
var list = [{
sex : 0,
name : '小明'
},{
sex : 1,
name : '小花'
}]
return select * from list t where t.sex = 0
结果:
{
"sex": 0,
"name": "小明"
}
五、结合 mica 使用
5.1 加入 mica-bom 依赖
<dependencyManagement>
<dependencies>
<dependency>
<groupId>net.dreamlu</groupId>
<artifactId>mica-bom</artifactId>
<version>${mica.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
5.2 mica-logging 无缝接入
mica-logging 的接入比较简单加入依赖即可:
注意:更多配置,如 json 日志和 logstash 日志收集请查看 mica 文档。
5.3 mica-captcha 验证码
base64 验证码:
5.4 mica-ip2region ip 转位置信息
示例项目源码:https://gitee.com/596392912/magic-api-example
从 mica 的接入可以看出,magic-api 的扩展性非常好,更多的自定义配置和扩展我们可以查看官方文档:
六、低代码开源
前端:
amis(百度前端低代码框架):https://github.com/baidu/amis
Sortable:https://github.com/SortableJS/Sortable
码良:https://gitee.com/ymm-tech/gods-pen
h5-Dooring:https://github.com/MrXujiang/h5-Dooring
后端:
apijson:https://github.com/Tencent/APIJSON
dataway:https://gitee.com/zycgit/hasor
magic-api:https://gitee.com/ssssssss-team/magic-api
七、总结
基于 magic-api 等开源项目我们也可以搭建自己的低代码平台。当然开发这个低代码平台我们还是需要些工作量,主要是打通 web ui 和后端接口的 api。笔者曾经也经历过一个电商项目,很多活动都是周五下午接到需求,周一就必须要上线。借助 magic-api 这类低代码工具我们可以快速完成这类需求。最后,希望这篇文章对大家有所启发。