Swagger는 나머지 API의 새 인터페이스를 인식하지 못합니다.
이것은 swagger 구성 파일입니다.
package trn06.administracion.api.configuration;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import lombok.extern.slf4j.Slf4j;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Slf4j
@EnableSwagger2
@Configuration
public class TRN06SwaggerConfiguration {
@Value("${custom.host}")
private String hostValue;
private ApiInfo _apiInfo(final String version) {
return new ApiInfoBuilder()
.title("Administrative events")
.termsOfServiceUrl("")
.version(version)
.contact(new Contact("",
"",
""))
.build();
}
private Docket _configureVersion(final String version) {
// Get environment from java environment variables
return new Docket(DocumentationType.SWAGGER_2)
.host(hostValue)
.groupName("Version_" + version)
.select()
.apis(RequestHandlerSelectors.basePackage("trn06.administracion.api.controller.rest"))
.paths(PathSelectors.ant("/v" + version + "/**"))
.build()
.useDefaultResponseMessages(false)
.apiInfo(_apiInfo(version));
}
@Bean
Docket configureV1_0() {
return _configureVersion("1.0");
}
}
패키지 trn06.administracion.api.controller.rest에 정의 된 모든 인터페이스는 괜찮습니다. 사실 다음을 제외하고 두 개의 다른 인터페이스가 정상적으로 매핑되었습니다.
package trn06.administracion.api.controller.rest;
import io.swagger.annotations.*;
import org.springframework.web.bind.annotation.GetMapping;
import trn06.administracion.api.model.dto.TRN06ErrorDto;
import trn06.administracion.api.model.dto.TRN06EventsAuthorityDto;
import trn06.administracion.api.model.dto.TRN06ValidationErrorDto;
import java.util.List;
@Api(value = "authorities", description = "Event's authorities ", tags = "Authorities")
public interface TRN06EventsAuthorityApiController {
@ApiOperation(value = "List of authorities", nickname = "findAuthorities", response = TRN06EventsAuthorityDto.class, responseContainer = "List", tags = {"Authorities,"})
@ApiResponses(value = {
@ApiResponse(code = 200, message = "Operation performed", response = TRN06EventsAuthorityDto.class, responseContainer = "List"),
@ApiResponse(code = 400, message = "Validation error", response = TRN06ValidationErrorDto.class),
@ApiResponse(code = 404, message = "Not found"),
@ApiResponse(code = 500, message = "Error", response = TRN06ErrorDto.class)})
@GetMapping(value = "/v1.0/authorities",
produces = "application/json")
List<TRN06EventsAuthorityDto> findAuthorities();
}
괜찮은 데이터베이스 엔티티처럼 보입니다. 오류를 시도하고 올바르게 감지되었습니다. RequestHandlerSelectors를 동일한 결과로 any ()로 변경하십시오.
무슨 일이 일어나고 있는지 전혀 모르고 단서도 없습니다.
종류 안부
이 인터페이스의 구현을 만들고 구현에 @RestController 및 @RequestMapping 주석을 추가 해야합니다.
예를 들면 :
@RestController
@RequestMapping("/findAuthorities")
public class TRN06EventsAuthorityApiControllerImpl implements TRN06EventsAuthorityApiController {
@Override
public List<String> findAuthorities() {
return null;
}
}
이 기사는 인터넷에서 수집됩니다. 재 인쇄 할 때 출처를 알려주십시오.
침해가 발생한 경우 연락 주시기 바랍니다[email protected] 삭제
몇 마디 만하겠습니다