Spring Boot中使用Swagger3.0.0注解

本文涉及的产品
智能开放搜索 OpenSearch行业算法版,1GB 20LCU 1个月
实时计算 Flink 版,1000CU*H 3个月
实时数仓Hologres,5000CU*H 100GB 3个月
简介: Spring Boot中使用Swagger3.0.0注解

image.png

四、注解说明

注意:注解中其实会有很多的属性,该文章只列出部分常用的属性而已,其他不常用属性请查看其他人博客!

@Api

@Api

@Api : 
    位置:用在请求的类上,例如Controller,
    作用:说明该类的主要作用。
    参数说明:@Api("tags":"", "value":"", "description ":"")
        tags:说明该类的作用,参数是个数组,可以填多个。
        value="该参数没什么意义,在UI界面上不显示,所以不用配置"
        description = "用户基本信息操作"

代码示例如下:

@RestController
@RequestMapping("/swagger")
@Api(tags = "用户管理")
@Slf4j
public class SwaggerController {
   }

网站效果展示:
image.png


@ApiOperation

@ApiOperation

@ApiOperation:
    位置:用在请求方法上
    作用:说明方法的用途、作用
    参数说明:@ApiOperation("value":"", "notes":"", "tags ":"")
        value="方法的用途和作用"
        notes="方法的注意事项和备注"            
        tags:说明该方法的作用, 参数是个数组,可以填多个。例如格式:tags={
   "作用1","作用2"}

代码示例如下:

@GetMapping("/getList")
@ApiOperation(value = "分页查询", notes = "分页查询的注意事项和备注", tags = {
   "说明该方法的作用1,说明该方法的作用2"})
public Response<PageResult<User>> getList(@RequestParam int pageNo, @RequestParam int pageSize){
   

网站效果展示:
image.png


@ApiImplicitParams

@ApiImplicitParams

@ApiImplicitParams: 
    位置:用在请求方法上
    作用:包含多@ApiImplicitParam,包含一组参数说明。
    参数说明:@ApiImplicitParams({
   @ApiImplicitParam("name":"", "value":"", "dataType":"", "paramType":"", "required":"")...})

代码示例如下:

@GetMapping("/getList")
@ApiOperation(value = "分页查询", notes = "分页查询的注意事项和备注", tags = {
   "说明该方法的作用1,说明该方法的作用2"})
@ApiImplicitParams({
   
    @ApiImplicitParam(name = "pageNo", value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") ,
    @ApiImplicitParam(name = "pageSize", value = "每页显示记录数", paramType = "query",required = true, dataType="int") ,
    })
public Response<PageResult<User>> getList(@RequestParam int pageNo, @RequestParam int pageSize){
   

@ApiImplicitParam

@ApiImplicitParam

@ApiImplicitParam:
    位置:用在请求方法上
    作用:用在@ApiImplicitParams注解中,指定一个请求参数的各个方面说明
    参数说明:@ApiImplicitParam("name":"", "value":"", "dataType":"", "paramType":"", "required":"")
        name="参数名称"
        value="参数说明"
        dataType="数据类型",默认String
        required=true 参数是否必选
        paramType="query" 表示参数放在哪里,查询参数类型,这里有几种形式:
            header --> 请求参数的获取:@RequestHeader,参数在 request headers 里边提交
            query --> 请求参数的获取:@RequestParam,直接跟参数,完成自动映射赋值
            path(用于 restful 接口)--> 请求参数的获取:@PathVariable,以地址的形式提交数据
            body(不常用)--> 以流的形式提交 仅支持 POST
            form(不常用)--> 以 form 表单的形式提交 仅支持 POST

代码示例如下:

@GetMapping("/getList")
@ApiOperation(value = "分页查询", notes = "分页查询的注意事项和备注", tags = {
   "说明该方法的作用1,说明该方法的作用2"})
@ApiImplicitParams({
   
    @ApiImplicitParam(name = "pageNo", value = "当前页码,从1开始", paramType = "query", required = true, dataType="int") ,
    @ApiImplicitParam(name = "pageSize", value = "每页显示记录数", paramType = "query",required = true, dataType="int") ,
    })
public Response<PageResult<User>> getList(@RequestParam int pageNo, @RequestParam int pageSize){
   

网站效果展示:
image.png


@ApiResponses

@ApiResponses

@ApiResponses:用在请求的方法上,表示一组响应

代码示例如下:

@GetMapping("/getList")
@ApiResponses({
   
     @ApiResponse(code=400,message="请求参数及格式不对"),
      @ApiResponse(code=404,message="请求路径没有或页面跳转路径不对")
    })
public Response<PageResult<User>> getList(@RequestParam int pageNo, @RequestParam int pageSize){
   

@ApiResponse

@ApiResponse

@ApiResponse:用在@ApiResponses中,一般用于表达一个错误的响应信息
    code:数字,例如400
    message:信息,例如"请求参数没填好"
    response:抛出异常的类

代码示例如下:

@GetMapping("/getList")
@ApiResponses({
   
    @ApiResponse(code=400,message="请求参数及格式不对"),
    @ApiResponse(code=404,message="请求路径没有或页面跳转路径不对")
})
public Response<PageResult<User>> getList(@RequestParam int pageNo, @RequestParam int pageSize){
   

网站效果展示:
image.png
image.png


image.png

重要信息

image.png
image.png

目录
相关文章
|
5天前
|
云安全 人工智能 安全
AI被攻击怎么办?
阿里云提供 AI 全栈安全能力,其中对网络攻击的主动识别、智能阻断与快速响应构成其核心防线,依托原生安全防护为客户筑牢免疫屏障。
|
15天前
|
域名解析 人工智能
【实操攻略】手把手教学,免费领取.CN域名
即日起至2025年12月31日,购买万小智AI建站或云·企业官网,每单可免费领1个.CN域名首年!跟我了解领取攻略吧~
|
9天前
|
安全 Java Android开发
深度解析 Android 崩溃捕获原理及从崩溃到归因的闭环实践
崩溃堆栈全是 a.b.c?Native 错误查不到行号?本文详解 Android 崩溃采集全链路原理,教你如何把“天书”变“说明书”。RUM SDK 已支持一键接入。
588 212
|
4天前
|
编解码 Linux 数据安全/隐私保护
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
教程分享免费视频压缩软件,免费视频压缩,视频压缩免费,附压缩方法及学习教程
233 138
|
存储 人工智能 监控
从代码生成到自主决策:打造一个Coding驱动的“自我编程”Agent
本文介绍了一种基于LLM的“自我编程”Agent系统,通过代码驱动实现复杂逻辑。该Agent以Python为执行引擎,结合Py4j实现Java与Python交互,支持多工具调用、记忆分层与上下文工程,具备感知、认知、表达、自我评估等能力模块,目标是打造可进化的“1.5线”智能助手。
827 60
|
7天前
|
人工智能 移动开发 自然语言处理
2025最新HTML静态网页制作工具推荐:10款免费在线生成器小白也能5分钟上手
晓猛团队精选2025年10款真正免费、无需编程的在线HTML建站工具,涵盖AI生成、拖拽编辑、设计稿转代码等多种类型,均支持浏览器直接使用、快速出图与文件导出,特别适合零基础用户快速搭建个人网站、落地页或企业官网。
1188 157
|
6天前
|
存储 安全 固态存储
四款WIN PE工具,都可以实现U盘安装教程
Windows PE是基于NT内核的轻量系统,用于系统安装、分区管理及故障修复。本文推荐多款PE制作工具,支持U盘启动,兼容UEFI/Legacy模式,具备备份还原、驱动识别等功能,操作简便,适合新旧电脑维护使用。
497 109
下一篇
oss云网关配置