gpt4 book ai didi

rest - 无法访问 Swagger 2 UI,部署在外部 tomcat 上的 Spring Boot 应用程序

转载 作者:行者123 更新时间:2023-11-28 22:48:40 24 4
gpt4 key购买 nike

我已经将war复制到apache-tomcat-8.0.43/webapps并使用./startup.sh启动tomcat。当我尝试访问 http://localhost:8080/swagger-ui.html ,我得到 404,但当我说 mvn spring-boot:run 时它正在工作。我是否缺少任何配置?示例代码如下:

package com.user;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.context.annotation.Bean;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

import static springfox.documentation.builders.PathSelectors.regex;

@SpringBootApplication
@EnableSwagger2
public class UserMicroServicesApplication extends SpringBootServletInitializer {
private static ConfigurableApplicationContext ctx;

@Override
protected SpringApplicationBuilder configure(SpringApplicationBuilder application) {
return application.sources(UserMicroServicesApplication.class);
}


public static void main(String[] args) throws Exception {
ctx = SpringApplication.run(UserMicroServicesApplication.class, args);
}

@Bean
public Docket productApi() {
return new Docket(DocumentationType.SWAGGER_2).select().apis(RequestHandlerSelectors.basePackage("com.user.controller")).paths(regex("/api.*")).build().apiInfo(apiInfo());
}

private ApiInfo apiInfo() {
return new ApiInfo("User API", "User service API.", "V1", "Terms of service", "", "", "");

}
}


controller class
-------------------

package com.user.controller;

import com.user.service.UserService;
import com.user.vo.UserVO;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.MediaType;
import org.springframework.web.bind.annotation.*;
import javax.validation.Valid;
import java.util.List;

@RestController
@RequestMapping(value = "/api")
public class UserController {

private static final Logger logger = LoggerFactory.getLogger(UserController.class);

@Autowired
private UserService userService;

@RequestMapping(value = "/user", method = RequestMethod.POST, produces = MediaType.APPLICATION_JSON_VALUE)
@ResponseStatus(HttpStatus.CREATED)
@ResponseBody
public UserVO createUser(@RequestBody @Valid UserVO user) {
logger.debug("creating user with email = {}", user);
UserVO updatedUserVO = userService.createUser(user);
logger.debug("user created with id {}", updatedUserVO.getId());
return updatedUserVO;
}
}

POM.xml

<packaging>war</packaging>

<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>1.5.6.RELEASE</version>
<relativePath/>
</parent>


<dependencies>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-tomcat</artifactId>
<scope>provided</scope>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-cache</artifactId>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-hateoas</artifactId>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-jpa</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-rest</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-data-mongodb</artifactId>
<version>1.5.7.RELEASE</version>
</dependency>

最佳答案

您需要为链接添加上下文路径。

apache-tomcat-8.0.43/webapps/${war-name}

http://localhost:8080/ ${war-name}/swagger-ui.html

关于rest - 无法访问 Swagger 2 UI,部署在外部 tomcat 上的 Spring Boot 应用程序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47821242/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com