让人上瘾的新一代开发神器——Magic-API

 

介绍

Magic-API 是什么?

Magic-API是一个基于 Java语言,Spring Boot 生态的一个快速开发框架。以下为官方的介绍。

magic-api 是一个基于Java的接口快速开发框架,编写接口将通过magic-api提供的UI界面完成,自动映射为HTTP接口,无需定义Controller、Service、Dao、Mapper、XML、VO等Java对象即可完成常见的HTTP API接口开发

Magic-API能做什么?

Magic-API 可以开发HTTP接口、RESTful接口,能作为SpringBoot+Mybatis(包括SSH、SSM等)的替代方案。

使用 Magic-API 有什么优势?

Magic-API编写代码使用的脚本语言的Magic-Script,它语法和Java很相似,也和Javascript很相似,是吸取了二者语法的优势创造的新语言。

友好的语法意味着学习这个脚本语言的学习成本非常低。这样就不用专门去学一些不熟悉、古怪的语法、特殊的设定了。

对于熟悉Javascript和Java的程序员来说,使用Magic-API可以说是得心应手了。

语法学习成本低是一方面,另一方面是Magic-Script还支持一些比较前瞻、好用的福利语法。比如你可以放心地使用多行字符串(JDK13中的文本块""",新增的语法)、Javascript ES6中的模板字符串(形如`${变量取值}`),而不用担心你使用的JDK版本仅仅是8。

另一个能大大提高开发效率的,是因为每次改完Magic-API的代码不需要去重启项目。虽然使用IDEA配合一些jRebel之类的插件也可以做到,但是,使用这些热加载的方式写Java代码还是会有一些局限的(比如热加载的reload速度、新写方法的方法签名变化、重新注入Spring环境等问题)。

在效率方面,Magic-Script的代码也会经过解析、编译为AST,再编译为字节码去执行(1.4.0以前的版本为解释执行)。效率相比纯Java硬编码而言肯定是比不过,不过比那种解析执行的语言会好得多。在普遍的场景下,执行性能也绝不会成为瓶颈。

关于调试:使用Magic-API的开发过程中,还可以进行debug,调试比较方便,比一些基于Nashorn引擎的框架更有优势。

导入模块:Magic-API可以导入Spring中的bean、Java中的类以及其他Magic-API接口、Magic-API中的模块、函数。内置了方便操作的一些模块:数据库操作、redis操作、mongo操作、http请求、log日志、request请求模块、response响应模块、env环境模块等。

Magic-API使用浏览器作为开发过程中的编辑器。你甚至可以在平板电脑、手机上、在家里(只要网络能连上)就可以访问到编辑器开发了。想想看,简直可以随时随地进行开发(oh no...)。

既然使用浏览器可以随意访问,那么如何保证安全性呢?开发环境可以对访问Magic-API界面设置用户名和密码,如果是线上环境,还可以根据需要关闭在线编辑功能,防止代码被修改。

使用Magic-API还可以依托JavaSpring生态上的优势。这样使得集成一些可以集成Spring的框架和组件更加方便。让代码写起来更简洁、更顺手,让Javaer的开发变得更高效、便捷。

那么我们来开始吧

需要先了解那些知识?

你需要懂一些基本的计算机知识,比如安装Java环境、使用Maven、了解一些Spring Boot的知识,这个是最基本的。如果你刚好是一名Java EE开发人员,那就最好不过了。

引用依赖

是的。需要在pom.xml中添加magic-api-spring-boot-starter的依赖。version则需要填最新的版本号(话说这版本号更新的老快了)。

如果你使用的是gradle,也类似,需要用gradle的方式添加依赖

 
 
 
 

还有一个properties文件中的配置。下面是官方文档的配置

 
 
 
 

启动项目

使用IDE中的方式启动Spring Boot项目。如果不出意外的话,就可以看到控制台打印出Magic-API的访问路径了。

我在使用中配置了哪些东西?

配置

下面是关于Magic-API的一些配置内容:

 
 
 
 

默认是会把写的代码存到本地磁盘文件的。可以通过magic-api.resource.type设置为数据库存储。

最后的magic-api.editor-config配置项指定了前端编辑器的一些字体配置,内容如下,位置位于classpath(maven 的 resources目录),文件名:magic-editor-config.js

 
 
 
 

数据源配置

再来说数据源的部分,数据源部分是把源代码的保存指定了单独的一个位置。数据源的配置内容如下:

 
 
 
 

Spring Boot 的配置类文件:

 
 
 
 

其中的指定的source数据源最后就会被用来存储使用Magic-API编写的源码。

这样做的目的是把代码存储和业务数据进行隔离,防止存放代码的数据库被误操作删除。

除了把代码存到数据库,还可以选择存到文件中。

SQL 打印配置

刚才提到我关闭了默认的SQL打印日志,我有个自己写的实现。还是在MagicApiConfig中添加一个自定义的SQL打印的Bean

 
 
 
 

还需要写另一个Config类,这个主要是对log模块的打印处理。这个Config类跟刚刚的作用不太一样,执行的时机略有区别,所以添加了@AutoConfigureAfter

 
 
 
 

自定义结果结构、错误提示

我还对错误提示进行覆写,根据自己的需要重写。在下面,还对列表查询的结果类型进行了改造,便于后续调用后修改结构:

 
 
 
 

开始使用

magic-script 的语法语句行位可以写分号,也可以不写分号,用换行表示,这一点和javascript很像。

界面

图片来自官方文档

整体说明

接口信息

RequestBody

ResponseBody

debug

 

以下是一些比喻的、特别的、以及比较好用的语法介绍。

导入

导入是指import指令。比Java中的import功能更多。

导入类

import 可以导入某个类,例如:

 
 
 
 

这样导入之后,我们就可以正常使用System这个类了,比如执行System.out.println()

导入还可以写别名,例如:

 
 
 
 

这样就可以用别名Sys来使用System这个类了。比如Sys.out.println()。但是这样好像看起来很奇怪,在特定场景下再去用吧

导入并 new 实例:

 
 
 
 

框架默认已经导入了 java.util.* ,所以不需要写导入Date也可以直接书写。使用的时候直接写new Date()就可以啦。

导入 Spring 中的 Bean

import 可以导入 Spring 中的 Bean,例如:

 
 
 
 

这样可以导入一个DataSource的bean,后续可以使用ds作为变量来使用了。

导入模块

improt 还可以导入模块,例如导入日志模块并使用:

 
 
 
 

退出语法

magic-api 中的退出语法是指exit,作用是退出本次请求,并返回一些数据。类似于return,但是能传递更多的信息。比如某个入参条件不满足,可以使用exit 400, '参数不正确',这样就可以返回给前端接口数据了。

 

……

评论区
回复