Spring Boot 如何在Sping Boot 3上运行Swagger 3

vfwfrxfs  于 2022-12-04  发布在  Spring
关注(0)|答案(2)|浏览(245)

在Java17和Sping Boot 3.0.0中使用一个新的Spring Initialzr,并在Springfox Swagger 3的pom.xml中添加一个额外的内容,我无法让Swagger页面正常工作,相反,我得到了一个带有404的白标签错误页面。
Pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>3.0.0</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.example</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<description>Demo project for Spring Boot</description>
<properties>
    <java.version>17</java.version>
</properties>
<dependencies>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>

    <dependency>
        <groupId>io.springfox</groupId>
        <artifactId>springfox-boot-starter</artifactId>
        <version>3.0.0</version>
    </dependency>

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

<build>
    <plugins>
        <plugin>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-maven-plugin</artifactId>
        </plugin>
    </plugins>
</build>
</project>

Github Issues page中定义的标准Swagger URL不适用于上面的pom.xml项目。

wpx232ag

wpx232ag1#

最新的springfox-boot-starter版本3.0.0和springdoc-openapi-ui版本1.6.13
似乎不支持Spring Boot3。
我们需要等到新版本采用jakarta.servlet包之后再进行。

wmvff8tz

wmvff8tz2#

我已经放弃了,在发布了这个问题后,我去使用了Sping Boot 2.7。在看到Dmitriy的答案后,我最后一次检查了Springdoc,发现Springdoc v2 does support Spring Boot 3
从本质上讲,一个人必须在他们的pom中放置以下内容:

<dependency>
      <groupId>org.springdoc</groupId>
      <artifactId>springdoc-openapi-starter-webmvc-ui</artifactId>
      <version>2.0.0</version>
   </dependency>

然后可以使用以下URL访问Swagger页面:http://localhost:8080/swagger-ui.html(如果需要,请不要忘记添加上下文路径)。由于某种原因,在打开时,它会重定向到http://localhost:8080/swagger-ui/index.html,尽管最初返回的是404...

相关问题