Inhaltsverzeichnis
Einführung der Swagger2-Abhängigkeit
Konfigurationsdatei erstellen
Heim Java javaLernprogramm SpringBoot integriert Swagger2, um Schnittstellendokumente zu generieren. Mama muss sich keine Sorgen mehr machen, dass ich API-Dokumente schreibe.

SpringBoot integriert Swagger2, um Schnittstellendokumente zu generieren. Mama muss sich keine Sorgen mehr machen, dass ich API-Dokumente schreibe.

May 26, 2020 pm 06:36 PM
1

Im aktuellen Entwicklungsprozess werden API-Schnittstellen grundsätzlich für die Systementwicklung verwendet. Daher ist in diesem Prozess ein gutes API-Dokument zum Backend und Frontend für Kommunikation und Entwicklung geworden.

Der traditionelle Ansatz besteht darin, dass Entwickler ein RESTful-API-Dokument erstellen, um alle Schnittstellendetails aufzuzeichnen. Ehrlich gesagt ist der Arbeitsaufwand nicht gering und sehr trivial, und wenn das Projekt aktualisiert wird, treten die folgenden Probleme auf geschehen.

  • Die Dokumentation ist schwierig zu pflegen.

  • Der Inhalt der Benutzeroberfläche ist komplexer und die Schreibeffizienz geringer.

Swagger soll dieses Problem lösen. Als standardisiertes und vollständiges Framework kann es zum Generieren, Beschreiben, Aufrufen und Visualisieren von Webdiensten im RESTful-Stil verwendet werden:

Durch Mit Swagger können wir API-Schnittstellendokumente mithilfe von Anmerkungen während des Schnittstellenentwicklungsprozesses automatisch generieren/aktualisieren und das Schnittstellen-Debugging auf der Dokumentationsseite unterstützen.

Als nächstes sprechen wir kurz darüber, wie man Swagger2 in SpringBoot integriert (2 stellt seine Version dar)

Einführung der Swagger2-Abhängigkeit

pom.xml Datei

<dependencies>
        <!--Swagger2 在此,个人推荐使用2.8.0版本,较为稳定-->
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger2</artifactId>
            <version>2.8.0</version>
        </dependency>
        <dependency>
            <groupId>io.springfox</groupId>
            <artifactId>springfox-swagger-ui</artifactId>
            <version>2.8.0</version>
        </dependency>
</dependencies>
Nach dem Login kopieren

Konfigurationsdatei erstellen

Swagger2Config.javaJava-Konfigurationsdatei

@Configuration
// 指定扫描的api包路径
@ComponentScan(basePackages = {"cn.beatree.xxx.controller"})
//注解开启 swagger2 功能
@EnableSwagger2
public class Swagger2Config {
    @Value("${swagger2.enable}")
    boolean enable;
    // 配置文件中通过值注入控制生产环境与开发环境下的启用状态
    @Bean
    public Docket createRestApi() {
        return new Docket(DocumentationType.SWAGGER_2)
                .enable(enable)
                .apiInfo(apiInfo())
                .select()
                .apis(RequestHandlerSelectors.any())
                .paths(PathSelectors.any())
                .build();
    }
    private ApiInfo apiInfo() {
        return new ApiInfoBuilder()
                .title("ANONVOTE | Swagger API文档")//标题
                .description("description: ANONVOTE | Swagger API文档")//描述
                .contact("BEATREE")//作者信息
                .version("1.0.0")//版本号
                .build();
    }
}
Nach dem Login kopieren

application.ymlKonfigurationsdatei

swagger2:
  enable: false #true 启用
Nach dem Login kopieren

@Configuration Annotation, die als Konfigurationsklasse bezeichnet wird, wird beim Start von SpringBoot geladen.

@EnableSwagger2 Annotation zum Aktivieren von Swagger2.

Mitgliedsmethode createRestApi Funktion erstellt das Docket Bean, apiInfo() Grundlegende Informationen, die zum Erstellen der API verwendet werden (diese grundlegenden Informationen werden auf der Dokumentationsseite angezeigt). Die Funktion select() gibt einen ApiSelectorBuilder zurück Die Instanz wird verwendet, um zu steuern, welche Schnittstellen Swagger zur Anzeige bereitgestellt werden. In diesem Beispiel wird sie durch Angabe des gescannten Paketpfads definiert, der alle Controller unter dem Paket scannt. Definiert die API und erzeugt Dokumentationsinhalte (außer für Anfragen, die durch @ApiIgnore angegeben werden).

Häufig verwendete Swagger-Anmerkungen

@Api: Ändern Sie die gesamte Klasse und beschreiben Sie die Rolle des Controllers

@ApiOperation: beschreibt eine Methode einer Klasse oder einer Schnittstelle

@ApiParam: beschreibt einen einzelnen Parameter @ApiModel : Verwendet ein Objekt zum Empfangen von Parametern

@ApiProperty: Wenn Sie ein Objekt zum Empfangen von Parametern verwenden, beschreiben Sie ein Feld des Objekts

@ApiResponse: Eine Beschreibung der HTTP-Antwort

@ApiResponses: Die Gesamtbeschreibung der HTTP-Antwort

@ApiIgnore : Verwenden Sie diese Annotation, um diese API zu ignorieren

@ApiError : Informationen, die zurückgegeben werden, wenn ein Fehler tritt auf

@ApiImplicitParam: Beschreibt einen Anforderungsparameter, Sie können die chinesische Bedeutung des Parameters konfigurieren und Sie können auch den Standardwert für den Parameter festlegen

@ApiImplicitParams: Beschreibt eine Anforderungsparameterliste, die aus mehreren mit

@ApiImplicitParam annotierten Parametern besteht

Zum Beispiel

@RestController
@Transactional    // 事务注解,实现回滚
@RequestMapping("/api/tlink")
@Api(value = "/api/tlink", tags = "参与者相关接口")
public class TlinkController{
    @GetMapping("/checkCode/{code}")
    @ApiOperation(value = "投票认证码核验接口",
            notes = "该接口用于核验认证码合法性,对于投票主题内容的获取需后续调用Topic相关接口。返回值data中带有参数 topic & options")
    public JSONObject checkCode(@PathVariable("code") String code){
  ...
 }
}
Nach dem Login kopieren

Zuletzt, nachdem Sie das SpringBoot-Projekt ausgeführt haben, greifen Sie über die Serveradresse /swagger-ui.html darauf zu.

Es ist zu beachten, dass, wenn ein Pfad-Interceptor hinzugefügt wurde, der Swagger-Pfad über

.excludePathPatterns("/swagger-resources/**", "/webjars/**", "/v2/**", "/swagger-ui.html/**")
Nach dem Login kopieren

freigegeben werden muss.

Das obige ist der detaillierte Inhalt vonSpringBoot integriert Swagger2, um Schnittstellendokumente zu generieren. Mama muss sich keine Sorgen mehr machen, dass ich API-Dokumente schreibe.. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
3 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Wie man alles in Myrise freischaltet
1 Monate vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle? Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle? Mar 17, 2025 pm 05:35 PM

Mit der Klassenbelastung von Java wird das Laden, Verknüpfen und Initialisieren von Klassen mithilfe eines hierarchischen Systems mit Bootstrap-, Erweiterungs- und Anwendungsklassenloadern umfasst. Das übergeordnete Delegationsmodell stellt sicher

Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache? Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache? Mar 17, 2025 pm 05:44 PM

In dem Artikel wird in der Implementierung von mehrstufigem Caching in Java mithilfe von Koffein- und Guava-Cache zur Verbesserung der Anwendungsleistung erläutert. Es deckt die Einrichtungs-, Integrations- und Leistungsvorteile sowie die Bestrafung des Konfigurations- und Räumungsrichtlinienmanagements ab

Wie kann ich JPA (Java Persistence-API) für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden verwenden? Wie kann ich JPA (Java Persistence-API) für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden verwenden? Mar 17, 2025 pm 05:43 PM

In dem Artikel werden mit JPA für Objektrelationszuordnungen mit erweiterten Funktionen wie Caching und faulen Laden erläutert. Es deckt Setup, Entity -Mapping und Best Practices zur Optimierung der Leistung ab und hebt potenzielle Fallstricke hervor. [159 Charaktere]

Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung? Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung? Mar 17, 2025 pm 05:46 PM

In dem Artikel werden Maven und Gradle für Java -Projektmanagement, Aufbau von Automatisierung und Abhängigkeitslösung erörtert, die ihre Ansätze und Optimierungsstrategien vergleichen.

Wie erstelle und verwende ich benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning und Abhängigkeitsmanagement? Wie erstelle und verwende ich benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning und Abhängigkeitsmanagement? Mar 17, 2025 pm 05:45 PM

In dem Artikel werden benutzerdefinierte Java -Bibliotheken (JAR -Dateien) mit ordnungsgemäßem Versioning- und Abhängigkeitsmanagement erstellt und verwendet, wobei Tools wie Maven und Gradle verwendet werden.

See all articles