萌新妹纸不会写后端代码,还不是照样开发API速度贼快

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS PostgreSQL,集群系列 2核4GB
简介: 萌新妹纸不会写后端代码,还不是照样开发API速度贼快

Magic-API 是什么

Magic-API是一个接口框架,可以快速开发服务接口程序,是一个纯Java开源项目。

开发人员只要用magic-api的可视化界面完成,无需Java编码,配置完成后,自动发布为HTTP服务。

什么,你还写controller、dao?这种Java类根本不用写,只要配置脚本,就能完成绝大部分的Restful服务开发。

简化所需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、不写dao、没有orm配置、没有实体类等针对此表的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的实现,我们要求request传入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

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
打赏
0
相关文章
微店API开发全攻略:解锁电商数据与业务自动化的核心能力
微店开放平台提供覆盖商品、订单、用户、营销、物流五大核心模块的API接口,支持企业快速构建电商中台系统。其API体系具备模块化设计、双重认证机制、高并发支持和数据隔离等特性。文档详细解析了商品管理、订单处理、营销工具等核心接口功能,并提供实战代码示例。同时,介绍了企业级整合方案设计,如订单全链路自动化和商品数据中台架构,以及性能优化与稳定性保障措施。最后,针对高频问题提供了排查指南,帮助开发者高效利用API实现电商数智化转型。适合中高级开发者阅读。
前后端分离开发:如何高效调试API?有工具 vs 无工具全解析
在前后端分离的开发模式中,API 调试的效率直接影响项目的质量和交付速度。通过本文的对比分析,我们可以看到无工具调试模式虽具备灵活性和代码复用能力,但在操作便利性和团队协作上稍显不足。而传统的外部调试工具带来了可视化、高效协作与扩展性,却可能存在工具切换带来的开发链路断层问题。Apipost-Hepler 融合了两者的优势,让开发者无需离开熟悉的 IDEA 环境,就能享受可视化调试工具的强大功能。
40 5
云原生应用实战:基于阿里云Serverless的API服务开发与部署
随着云计算的发展,Serverless架构日益流行。阿里云函数计算(Function Compute)作为Serverless服务,让开发者无需管理服务器即可运行代码,按需付费,简化开发运维流程。本文从零开始,介绍如何使用阿里云函数计算开发简单的API服务,并探讨其核心优势与最佳实践。通过Python示例,演示创建、部署及优化API的过程,涵盖环境准备、代码实现、性能优化和安全管理等内容,帮助读者快速上手Serverless开发。
实战指南:通过1688开放平台API获取商品详情数据(附Python代码及避坑指南)
1688作为国内最大的B2B供应链平台,其API为企业提供合法合规的JSON数据源,直接获取批发价、SKU库存等核心数据。相比爬虫方案,官方API避免了反爬严格、数据缺失和法律风险等问题。企业接入1688商品API需完成资质认证、创建应用、签名机制解析及调用接口四步。应用场景包括智能采购系统、供应商评估模型和跨境选品分析。提供高频问题解决方案及安全合规实践,确保数据安全与合法使用。立即访问1688开放平台,解锁B2B数据宝藏!
DeepClaude:结合 DeepSeek R1 和 Claude AI 各自优势开发的 AI 应用平台,支持 API 调用和零延迟的即时响应
DeepClaude 是一个开源的 AI 应用开发平台,结合了 DeepSeek R1 和 Claude 模型的优势,提供即时响应、端到端加密和高度可配置的功能。
303 4
DeepClaude:结合 DeepSeek R1 和 Claude AI 各自优势开发的 AI 应用平台,支持 API 调用和零延迟的即时响应
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
64 5
以项目登录接口为例-大前端之开发postman请求接口带token的请求测试-前端开发必学之一-如果要学会联调接口而不是纯写静态前端页面-这个是必学-本文以优雅草蜻蜓Q系统API为实践来演示我们如何带token请求接口-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
105 72
【01】对APP进行语言包功能开发-APP自动识别地区ip后分配对应的语言功能复杂吗?-成熟app项目语言包功能定制开发-前端以uniapp-基于vue.js后端以laravel基于php为例项目实战-优雅草卓伊凡
Java后端开发-使用springboot进行Mybatis连接数据库步骤
本文介绍了使用Java和IDEA进行数据库操作的详细步骤,涵盖从数据库准备到测试类编写及运行的全过程。主要内容包括: 1. **数据库准备**:创建数据库和表。 2. **查询数据库**:验证数据库是否可用。 3. **IDEA代码配置**:构建实体类并配置数据库连接。 4. **测试类编写**:编写并运行测试类以确保一切正常。
93 2
婚恋交友系统平台 相亲交友平台系统 婚恋交友系统APP 婚恋系统源码 婚恋交友平台开发流程 婚恋交友系统架构设计 婚恋交友系统前端/后端开发 婚恋交友系统匹配推荐算法优化
婚恋交友系统平台通过线上互动帮助单身男女找到合适伴侣,提供用户注册、个人资料填写、匹配推荐、实时聊天、社区互动等功能。开发流程包括需求分析、技术选型、系统架构设计、功能实现、测试优化和上线运维。匹配推荐算法优化是核心,通过用户行为数据分析和机器学习提高匹配准确性。
234 3
后端开发中的性能优化策略
本文将探讨几种常见的后端性能优化策略,包括代码层面的优化、数据库查询优化、缓存机制的应用以及负载均衡的实现。通过这些方法,开发者可以显著提升系统的响应速度和处理能力,从而提供更好的用户体验。
106 6

热门文章

最新文章