Swagger-core: Spring Boot + Jersey2 + Swagger2 Cela ne peut pas fonctionner en même temps

Créé le 2 juin 2016  ·  5Commentaires  ·  Source: swagger-api/swagger-core

Spring Boot + Jersey2 + Swagger2 Cela ne peut pas fonctionner en même temps

Exécution de l'application Spring Boot

BootStartInitialization.class

public static void main(String[] args) {
SpringApplication.run(BootStartInitialization.class, args);
}

<strong i="11">@Bean</strong>
public ServletRegistrationBean jerseyServlet() {
    ServletRegistrationBean registration = new ServletRegistrationBean(new ServletContainer(), "/api/*");
    registration.addInitParameter(ServletProperties.JAXRS_APPLICATION_CLASS, JerseyConfig.class.getName());
    return registration;
}

Configuration du maillot

la classe publique JerseyConfig étend ResourceConfig {

public JerseyConfig() {              

    register(io.swagger.jaxrs.listing.ApiListingResource.class);
    register(io.swagger.jaxrs.listing.SwaggerSerializers.class);          
    register(CrossDomainFilter.class);
    register(JacksonFeature.class);
    register(UserController.class);//this my api
}

}

Configuration Swagger2

@Configuration
@EnableSwagger2
classe publique Swagger2 {

<strong i="23">@Bean</strong>
public Docket createRestApi(ServletConfig config) {     
    return new Docket(DocumentationType.SWAGGER_2)
            //.pathProvider(pathProvider)
            .apiInfo(apiInfo())
            .select()
            .apis(RequestHandlerSelectors.basePackage("com.controller"))
            .paths(PathSelectors.any())
            .build();
}

private ApiInfo apiInfo() {
    return new ApiInfoBuilder()
            .title("Spring Boot中使用Swagger2构建RESTful APIs")
            .description("施工平台后台API")
            .termsOfServiceUrl("http://www.xxxx.com/")
            .contact("Jonathan")
            .version("1.0")
            .build();
}

Contrôleur API (Ressource)

@Composant
@Manette
@RequestMapping(value="/accounts")
@Path("/comptes")
@Api(value = "gestionnaire de comptes")
@Products(MediaType.APPLICATION_JSON)
@Consume(MediaType.APPLICATION_JSON)
public class UserController {

/**
 * <strong i="35">@Fields</strong> log slf4j logger
 */
private static Logger logger = LoggerFactory.getLogger(UserController.class);

<strong i="36">@POST</strong>
@ApiOperation(value = "Add a new user to the store")
public void create(@ApiParam(value = "Account object that needs to be added to the store", required = true) final String userName) {

}

@Path("{userId}")
<strong i="37">@GET</strong>
@ApiOperation(value = "Get user's Account by userId")
//@RequestMapping(value={"userId"}, method=RequestMethod.GET)
public String get(@ApiParam(value = "get user's account from db.", required = true) @PathParam("userId") final Integer userId) {
    if (userId != null) {
        return userId.toString();
    } else {
        return "userId is be can't null";
    }
}

}

ouvrez http://localhost :8080/swagger-ui.html, pas de document d'api d'affichage. sur la sous-API trouvée.
ne peut pas afficher le document http://localhost :8080/accounts/{userId} api.

Cela ne peut pas fonctionner en même temps

Spring Boot + Jersey + Swagger Vous ne courez pas?

qui est ce proche? Pourquoi ? cette question non résolue.

Commentaire le plus utile

mais c'est Spring Boot + Swagger2.0, pas de maillot, pas le stade de Jersey.

Je veux Spring Boot + Jersey + swagger.

Tous les 5 commentaires

mais c'est Spring Boot + Swagger2.0, pas de maillot, pas le stade de Jersey.

Je veux Spring Boot + Jersey + swagger.

Je vous suggère d'obtenir votre ressource à partir du contexte de printemps avant de vous inscrire dans votre configuration Jersey. Si vous voulez exécuter un aspect, vous aurez besoin de printemps pour être au courant.

WebApplicationContext springFactory = WebApplicationContextUtils.getWebApplicationContext(servletContext);
register(springFactory.getBean(UserController.class));

@youkuan j'ai le même problème. Avez-vous trouvé une solution?

Cette page vous a été utile?
0 / 5 - 0 notes