Maison >Java >javaDidacticiel >Comment utiliser Swagger dans SpringBoot

Comment utiliser Swagger dans SpringBoot

WBOY
WBOYavant
2023-05-17 20:16:101711parcourir

Intégrer Swagger

Dépendances :

<!-- Swagger -->
<dependency>
    <groupId>com.battcn</groupId>
    <artifactId>swagger-spring-boot-starter</artifactId>
    <version>2.1.5-RELEASE</version>
</dependency>

Vous avez peut-être remarqué que le Swagger que j'ai ici n'est pas officiel Celui-ci est intégré par un tiers, et la configuration est plus simple.

Explication détaillée de la configuration

Configuration détaillée :

spring:
  swagger:
    enabled: true
    title: 标题
    description: 描述信息
    version: 系统版本号
    contact:
      name: 维护者信息
    base-package: swagger扫描的基础包,默认:全扫描(分组情况下此处可不配置)
    #全局参数,比如Token之类的验证信息可以全局话配置
    global-operation-parameters:
    -   description: "Token信息,必填项"
        modelRef: "string"
        name: "Authorization"
        parameter-type: "header"
        required: true
    groups:
      basic-group:
        base-package: com.battcn.controller.basic
      system-group:
        base-package: com.battcn.controller.system

Ma configuration

spring:
  swagger:
    title: 星空小屋 - 文章微服务接口
    description: 文章微服务相关接口,包括文章、模块、知识点管理等
    version: 1.0.0 - SNAPSHOT
    contact:
      name: cv大魔王
      email: 1919301983@qq.com
    host: localhost
    enabled: true
    security:
      filter-plugin: true # 配置账号密码
      username: root
      password: root

Configurez l'intercepteur, et il y a la configuration de l'intercepteur derrière lui. Si des lecteurs ont besoin de l'utiliser dans leurs propres projets, veuillez le modifier dans l'intercepteur d'origine. configuration et ignorez-la. Les chemins suivants sont disponibles pour éviter d’être bloqués et inaccessibles. "swagger-ui.html", "static/css/", "static/js/", "swagger-resources", "/**/error", "v2/api-docs"

test d'utilisation

Exécutez le projet et accédez à IP+numéro de port/swagger-ui.html, par exemple, accédez dans le navigateur : http://127.0.0.1:13001/swagger-ui.htmlIP+端口号/swagger-ui.html,例如在浏览器访问:http://127.0.0.1:13001/swagger-ui.html

Comment utiliser Swagger dans SpringBoot

登录后的效果:

Comment utiliser Swagger dans SpringBoot

复习――常用注解

对swagger熟悉的小伙伴的请忽略“常用注解段落”

`@Api`:用在 Controller 类上,描述该类的作用
  1. `value`="描述信息"
  2. `description`="详细描述该类的作用"

@ApiOperation:用在 Controller 请求方法上,描述方法的作用。

@ApiModel:用在请求参数是对象上,描述该对象类的作用

// 在对象类上使用@ApiModel
@ApiModel(value="CategoryREQ对象", description="类别查询条件")
public class CategoryREQ extends BaseRequest<Category> {
}

@ApiModelProperty:用在请求参数是对象的属性上,描述对象属性的作用。

  • value:属性的描述

  • hidden:是否是查询条件属性, false:(默认值)在api文档显示,作为查询条件;true 隐藏,不是条件属性

// 请求方法参数是 CategoryREQ 对象
public Result search(@RequestBody CategoryREQ req) {}

@ApiModel(value="CategoryREQ对象", description="类别查询条件")
public class CategoryREQ extends BaseRequest<Category> {
    
    @ApiModelProperty(value = "分类名称")
    private String name;

    @ApiModelProperty(value="状态(1:正常,0:禁用)")
    private Integer status;
}
  • @ApiResponses:用在请求的方法上,用于表示一组响应

  • @ApiResponse:用在 @ApiResponses 中,一般用于表达一个错误的响应信息,注解参数:

  • code:数字,如 400message:信息,如 “参数填写错误”response:抛出异常的类

@ApiIgnore: 使用该注解忽略这个 API

@ApiImplicitParams:用在请求方法上,对多个请求参数增加描述

@ApiImplicitParam:可单独使用,或在 @ApiImplicitParams 中使用,给方法的一个请求参数增加描述。

  1. name:参数名

  2. value:描述参数的作用

  3. dataType:参数类型,参数类型,默认String,其它值 dataType=“Integer”

  4. defaultValue:参数默认值

  5. required:参数是否必传(true/false)

  6. paramTpye:指定参数放在哪些地方(header/query/path/body/form)

header :参数在request headers 里边提交 @RequestHeader
query :直接跟参数完成自动映射赋值 @RequestParam
path :以路径变量的形式提交数据 @PathVariable
body :以流的形式提交 仅支持POST(不常用)
form

🎜L'effet après la connexion : 🎜🎜 Comment utiliser Swagger dans SpringBoot🎜

Review - Common Annotations 🎜

Pour ceux qui sont familiers avec swagger, veuillez ignorer le "paragraphe d'annotation commun" 🎜

// 请求方法有多个请求参数 size, current
@ApiImplicitParams({
    @ApiImplicitParam(name="current", value="页码", required=true, paramType="path",dataType="int"),
    @ApiImplicitParam(name="size", value="每页记录数", required=true, paramType="path",dataType="int")
})
@ApiOperation("根据分类名称与状态查询分类列表接口")
@PostMapping("/search/{current}/{size}")
Result search(@RequestBody CategoryREQ req, @PathVariable int current, @PathVariable int size);
🎜@ApiOperation : utilisé sur le contrôleur méthode de requête pour décrire la fonction de la méthode. 🎜🎜@ApiModel : Utilisé lorsque le paramètre de requête est un objet, décrivant le rôle de la classe d'objet 🎜rrreee🎜@ApiModelProperty : Utilisé lorsque le paramètre de requête est la propriété d'un objet , décrivant le rôle des propriétés des objets. 🎜
  • valeur : Description de l'attribut🎜

  • caché :Qu'il s'agisse d'un attribut de condition de requête, false : (valeur par défaut) est affiché dans le document API car une condition de requête est masquée, pas un attribut de condition🎜

rrreee
  • @ApiResponses : utilisé sur les méthodes de requête pour représenter un ensemble de réponses🎜

  • @ApiResponse : Utilisé dans <code>@ApiResponses, généralement utilisé pour exprimer un message de réponse d'erreur, paramètres d'annotation : 🎜

  • code : nombre, tel que 400 message : informations, telles que "Erreur de remplissage des paramètres" réponse : la classe qui lève l'exception🎜

🎜@ ApiIgnore : utilisez cette annotation pour ignorer cette API🎜🎜@ApiImplicitParams : utilisé sur les méthodes de requête pour ajouter des descriptions à plusieurs paramètres de requête🎜🎜@ApiImplicitParam : peut être utilisé seul, ou dans Utilisé dans @ApiImplicitParams pour ajouter une description à un paramètre de requête de la méthode. 🎜
  1. nom : Nom du paramètre🎜

  2. valeur : Décrivez le rôle des paramètres🎜

  3. dataType : type de paramètre, type de paramètre, chaîne par défaut, autres valeurs dataType = "Integer"🎜

  4. defaultValue : La valeur par défaut du paramètre🎜

  5. obligatoire : Indique si le paramètre doit être transmis (vrai/faux) 🎜

  6. paramTpye : Spécifiez où les paramètres sont placés (en-tête/requête/chemin/corps/formulaire)🎜

🎜 header : Les paramètres sont dans Soumettre @RequestHeader dans les en-têtes de requête🎜query : Effectuer le mappage et l'affectation automatiques directement avec les paramètres @RequestParam🎜path : Soumettre les données dans le forme de variables de chemin @PathVariable🎜body : La soumission sous forme de flux ne prend en charge que le POST (pas couramment utilisé) 🎜<code>form : La soumission sous forme de formulaire ne prend en charge que le POST ( pas couramment utilisé) 🎜Référence : 🎜rrreee

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer