MagicAPI快速入门

经理:小王,隔壁组要读我们的数据,赶紧把接口程序做一下!
经理:小王,五年前的jsp项目,能不能把商品信息改造一下,做一个数据api?
经理:小王,明天要给可以做一个大屏展示,今天能把数据接口调好吗?、

王小面:我太难了@~@
经理:你还在手工写 RestController?试试 “接口配置服务” 啊

Magic-API 是什么

Magic-API是一个基于Java的接口快速开发框架,编写接口将通过magic-api提供的UI界面完成,自动映射为HTTP接口。
在这里插入图片描述

无需定义Controller、Service、Dao、Mapper、XML、VO等Java对象即可完成常见的HTTP API接口开发。

简化所需Java知识背景,只要会写SQL,直接就能做数据

一、特点

  1. 支持常规关系型数据库,比如MySQL,Oracle等常见的
  2. Redis、MongoDB、ES等非关系型,DataW等同类产品不支持
  3. 配置数据以文件形式存放,DataW等需要建个数据库存配置
  4. 支持在线调试
  5. 支持参数配置,比如必填、格式等等
  6. 支持Linq,做.net的觉得很好,未来可期
  7. 支持API实现上传下载
  8. 支持脚本中混排Java代码
  9. 支持脚本的版本管理

二、尝试使用

2.1 准备工作

数据库:MySQL

表:用户信息表 t_user

列名含义类型
id序号integer
account登录名varchar
name昵称varchar
gender性别varchar
avatar头像varchar

2.2 目标

  1. 不写Controller、Service、Dao等针对此表的Java代码
  2. 快速创建针对表CRUD的API
  3. 实现复杂的查询数据API
  4. 接口参数控制管理

三、开发步骤

3.1 创建新项目

1.新建SpringBoot项目:magicdemo,包名 com.demo.magic

2.pom.xml加入以下内容

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter</artifactId>
</dependency>

<dependency>
	<groupId>org.springframework.boot</groupId>
	<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>

<dependency>
	<groupId>org.ssssssss</groupId>
	<artifactId>magic-api-spring-boot-starter</artifactId>
	<version>2.0.1</version>
</dependency>

<dependency>
	<groupId>mysql</groupId>
	<artifactId>mysql-connector-java</artifactId>
	<scope>runtime</scope>
</dependency> 

3.配置application.yml

简易配置,只需配置以下内容

magic-api:
  resource:
    location: d:/cfg/magic-api #配置文件存储位置。当以classpath开头时,为只读模式
  web: /magic/web #配置web页面入口
server:
  port: 6408
spring:
  datasource:
    driver-class-name: com.mysql.cj.jdbc.Driver
    url: jdbc:mysql://192.168.2.133:3306/test?useSSL=false&characterEncoding=utf-8&serverTimezone=Asia/Shanghai
    username: testuser
    password: testpass
    type: com.zaxxer.hikari.HikariDataSource

如果需要,可以对magic-api的内容做更复杂的配置,例如:

magic-api:
  resource:
    location: d:/cfg/magic-api #配置文件存储位置。当以classpath开头时,为只读模式
  web: /magic/web #配置web页面入口
  page: # 可不配置, 后续内容全会用默认值
    size: size # 页大小的请求参数名称 缺省时为size
    page: page # 页码的请求参数名称 缺省时为page
    default-page: 1 # 自定义默认首页 缺省时为1
    default-size: 10 # 自定义为默认页大小 缺省时为10
  response-code: # 可不配置
    success: 200 #执行成功的code值
    invalid: 400 #参数验证未通过的code值
    exception: 500 #执行出现异常的code值

复杂配置可对分页、状态码等内容做自定义,具体可参考官方文档 https://www.ssssssss.org/magic-api

配置完成后,启动boot项目,控制台将会出现以下文字:

服务启动成功,magic-api已内置启动! Access URLs:
接口本地地址: 		http://localhost:6408/
接口外部地址: 		http://192.168.2.133:6408/
接口配置平台: 		http://192.168.2.133:6408/magic/web/index.html

此时打开配置平台地址就可以使用了,完全不用写业务代码

3.2 配置CRUD的API

本阶段目标:

1.通过配置完成 t_user 表的CRUD功能实现

2.仅做脚本配置,不写任何一个java文件

3.2.1 创建分组

点击新建分组

组名:用户管理
路径:user

3.2.2 创建查询列表

1.右键分组user,新建接口

2.下方接口信息里输入:

请求方法:get
接口名称:查询全部用户
接口路径:listall

3.右侧的大文本框内,输入以下脚本

return db.table('t_user').select()

4.点击右上方运行,或者ctrl+Q,就会在下方控制台输出响应内容

{
    "code": 200,
    "message": "success",
    "data": [{
        "id": 1,
        "account": "xiaoming",
        "name": "小明",
        "gender": "男",
        "avatar": "https://www.qq.com/logo.png"
    }, {
        "id": 2,
        "account": "xiaohong",
        "name": "小红",
        "gender": "女",
        "avatar": "https://www.qq.com/logo2.png"
    }],
    "timestamp": 1660810934840,
    "executeTime": 30
}

我们第一个API就实现完成了。

此时可以使用发布路径调试,在浏览器访问 http://192.168.2.133:6408/user/listall

就会看到和调试相同的结果。

3.2.3 创建保存方法

保存API的实现,我们要求请求传入body,为json格式的t_user表内容,然后进行保存

1.右键分组user,新建接口

2.下方接口信息里输入:

请求方法:post
接口名称:保存新用户
接口路径:save

3.右侧的大文本框内,输入以下脚本

return db.table('t_user').insert(body)

4.在下方接口信息的请求body里,输入以下内容,t_user表的id设为自增,body不赋值

{
    "account": "xiaoling",
    "name": "小玲",
    "gender": "女",
    "avatar": "https://www.qq.com/face.png"
}

点击右上方运行,就会在下方控制台输出响应内容

{
    "code": 200,
    "message": "success",
    "data": 4,
    "timestamp": 1660811763708,
    "executeTime": 22
}

5.此时查询数据库,就会看到新插入的记录了

3.2.4 创建更新方法

更新和保存很相似,仍然是通过post,将body内容更新数据表

1.前面步骤类似,创建update接口,脚本内容为:

# primary表示根据主键id进行更新
return db.table('t_user').primary("id").update(body)

2.测试body如下:

{
    "id": 3,
    "account": "xiaoling3",
    "name": "小玲3",
    "gender": "男",
    "avatar": "https://www.qq.com/face3.png"
}

结果提示成果,数据表内容也改了。

3.2.5 saveOrUpdate的实现

经常使用ORM的同学,习惯于用saveOrUpdate的方式,自动决定insert还是update,脚本里可以使用save实现:

# 1. 如果body里有id,则是update,否则是insert
db.table('t_good').primary('id').save(body)

# 2. 显式调用insert / update
db.table('t_good').primary('id').insert(body)
db.table('t_good').primary('id').update(body)

3.2.6 创建删除方法

步骤跟前面类似,关键的脚本如下:

db.table('t_user')
        .where()
        .eq("id", id)
        .delete()

此时,需要在接口的请求参数里,添加参数

id 3 integer

执行时就会删除where id=3的记录。

如果不传,则会认为是 where id is null

以上就是一套单表的简单CRUD接口创建过程

3.3 配置条件查询API

这个环节我们解决几个常见的数据查询用法

1.分页查询

2.手写SQL语句

3.带参查询

4.动态SQL语句

5.MyBatis风格写法

3.3.1 分页查询

简单用法,将原来的语句

return db.table('t_user').select()

改成

return db.table('t_user').page()

就可以了

此时请求参数,可以增加page和size作为条件

例如输入 page=1, size=5, 都是integer类型, 则会取第1页的5行记录

此处页码从1开始,有的数据库分页是从0开始的,这里统一按照人类习惯从1开始算页数。

3.3.2 手写SQL语句

前面的例子,都是针对单个表的查询,但我们经常需要对多个表进行联查,或者写一些特定的SQL语句,可以采用以下方法:

var sql="""
    select * from t_user order by id desc
"""
return db.select(sql)

三引号运算符,确保里面的内容无需被转义。这种写法可以完全自由发挥你的SQL书写能力。

3.3.3 查询参数使用

var sql="""
    select * from t_user where gender=#{gender} order by id
"""
return db.select(sql)

与上个例子相比,增加了gender参数,此时从请求参数处,会接收名为gender的参数

参数有两种使用方法,#{} 和 ${},区别为:

#{}时,输出查询语句为
select * from t_user where gender=? order by id

${}时,输出查询语句为
select * from t_user where gender='男' order by id

#采用防注入占位符方式,$采用字符拼接方式,因此在String参数时,脚本写法也不一样,以下两者是等价的,注意单引号
select * from t_user where gender=#{gender} order by id
select * from t_user where gender='${gender}' order by id

3.3.4 动态SQL语句

在做条件查询时,经常遇到参数不确定的情况,此时需要动态语句支持

例如:参数gender和name作为查询条件,都是可有可无的,则脚本如下:

var sql="""
    select * from t_user where 1=1 
        ?{gender!=null && gender!="", and gender=#{gender}} 
        ?{name!=null && name!="", and name like '%${name}%'} 
        order by id
"""
return db.select(sql)

?表示这一行是一个可选条件,如果满足,则增加 and xx=? 子句,实现了一个简单的sql语句拼接

同时我们也可以看到,针对like条件,用$传参更容易操作模糊匹配

3.3.5 动态SQL语句MyBatis的方式

前一种方法,如果用不习惯,还是需要花点时间理解的。

MagicAPI提供了类似MyBatis的写法,如下:

var sql="""
    select * from t_user where 1=1 
        <if test="gender!=null and gender!=''">
            and gender=#{gender}
        </if>
        <if test="name!=null and name!=''">
            and name like '%${name}%'
        </if>
    order by id
"""
return db.select(sql)

这种if方式,对于MyBatis或者jsp爱好者,看起来更为亲切。

3.4 接口参数控制

接口发布时,经常要对入参进行约束,包括:

1.参数必填和选填

2.入参的格式,例如手机号,身份证,长度和正则等验证

3.错误提示,如某个参数有误,给出的提示语

直接可以用MagicAPI的参数信息面板完成设置

3.4.1 参数必填、选填

勾中必填选项,则会进行入参验证,相当于写代码时自己Assert.notNull等操作

对非必填项,还可以设置默认值。注意,必填项的默认值无效,只有非必填参数没传参时,会采用默认值

3.4.2 参数类型

可以对参数类型进行选择,支持常规参数类型,以及附件格式

3.4.3 参数验证

支持表达式验证,和正则验证方式,结合表达式和验证说明配置,可以做出丰富的效果

正则验证:

参数 age
正则写为 ^\d+$
验证说明 age必须为数字

表达式验证

参数 mobile
表达式写为 mobile.length() == 11
验证说明 手机号必须是11位

这样我们就可以快速搭建好API服务了

更多示范请参考:

https://magic-api.ssssssss.org.cn/magic/web/index.html

# 1小时之后

王小面:经理,做完了
经理:测了吗?
王小面:当然啊,工具自带了冒烟测试呢
经理:干得漂亮,周末请你吃饭!
  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Magic-API 支持多数据源配置。在配置文件中,你可以通过修改以下配置来添加多个数据源: ``` spring.datasource.url=jdbc:mysql://localhost/test spring.datasource.username=root spring.datasource.password=123456789 spring.datasource.driver-class-name=com.mysql.jdbc.Driver ``` 这里的 `spring.datasource.url`、`spring.datasource.username`、`spring.datasource.password` 和 `spring.datasource.driver-class-name` 分别是配置数据库连接的 URL、用户名、密码和驱动类名。你可以根据实际情况,修改这些配置来连接你的其他数据源。 同时,你需要在代码中使用 `@DataSource` 注解来指定使用的数据源。在代码片段中,你可以看到 `DynamicDataSource.setDataSource()` 方法被调用来设置数据源,而 `DynamicDataSource.clearDataSource()` 方法则用于清除设置的数据源。 总结起来,Magic-API 提供了多数据源的支持,你可以在配置文件中配置多个数据源,并在代码中使用 `@DataSource` 注解来指定使用的数据源。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [magic-apiJava后端开发者的福音,接口开发利器](https://blog.csdn.net/java_xd/article/details/109712329)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [springboot多数据源](https://blog.csdn.net/magiconion/article/details/107488207)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

全粘架构师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值