Springboot Swagger in Short












0















While I was implementing Swagger , I found lot of help from the communities/blogs , but in one place . So I a summarizing the critical ones, just to save time for others..



1 . Need to include the dependencies..



        <!-- Added for Swagger Dependency -->
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger2</artifactId>
<version>2.8.0</version>
<scope>compile</scope>
</dependency>
<dependency>
<groupId>io.springfox</groupId>
<artifactId>springfox-swagger-ui</artifactId>
<version>2.8.0</version>
<scope>compile</scope>
</dependency>
<!--END Added for Swagger Dependency -->




  1. You need to have a Swagger config class ..



    @Configuration
    @EnableSwagger2
    public class SwaggerConfig extends WebMvcConfigurationSupport {



    @Bean
    public Docket productApi() {


    /* Swagger : For Particular Rest Service under somepackge, someEndpoint

    return new Docket(DocumentationType.SWAGGER_2).select()
    .apis(RequestHandlerSelectors.basePackage("com.abcdli.somepackge.controller"))
    .paths(PathSelectors.regex("/someEndpoint.*")).build();*/


    /* Swagger : Simple method for all the apis

    return new Docket(DocumentationType.SWAGGER_2).select()
    .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build();
    */

    /*
    Swagger : Simple method for all the apis under somepackage only
    */

    return new Docket(DocumentationType.SWAGGER_2).select()
    .apis(RequestHandlerSelectors.basePackage("com.abcdli.yourpackage.controller"))
    .paths(PathSelectors.any())
    .build()
    /*
    Swagger : metaInfo() is used for enrichment with details
    ApiInfo(title, description, version, termsOfServiceUrl, contactName, license, licenseUrl);
    */
    .apiInfo(metaInfo());



    }

    private ApiInfo metaInfo() {

    String description = ;


    return new ApiInfoBuilder()
    .title("YOUR APPLICATION NAME")
    .description(description)
    .version("1.0.0.1")
    .contact(new springfox.documentation.service.Contact("TEAM","www.mw.com","mw.abcd.com"))
    .build();


    }

    @Override
    protected void addResourceHandlers(ResourceHandlerRegistry registry) {
    registry.addResourceHandler("swagger-
    ui.html").addResourceLocations("classpath:/META-INF/resources/");

    registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
    }


    }




3 . Now the Swagger Page is ready . Now need customize the controller , methods and models. This is very straight forward.



/*
Registering the RestAPI
*/
@Api(value="YourController",description="some description")
public class YourController {
@RequestMapping(value = "/path", method = RequestMethod.POST,
consumes = {
"application/JSON" }, produces = { "application/JSON" })

/*
Registering the method
*/
@ApiOperation(value="Adding a method",response=Response.class)
public ResponseEntity<Response> addMethodDetails(
@RequestBody modifyReq) {

}




  1. You need provide access to these resources , if your API is secured with some authentication ..




    • //http.anonymous().disable(); [ anonymous ]


    • http.authorizeRequests()
      .antMatchers("/swagger-resources/",
      "swagger-resources/configuration/ui/*",
      "/swagger-ui.html
      ",
      "/webjars/**",
      "favicon.ico").permitAll();













share|improve this question



























    0















    While I was implementing Swagger , I found lot of help from the communities/blogs , but in one place . So I a summarizing the critical ones, just to save time for others..



    1 . Need to include the dependencies..



            <!-- Added for Swagger Dependency -->
    <dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger2</artifactId>
    <version>2.8.0</version>
    <scope>compile</scope>
    </dependency>
    <dependency>
    <groupId>io.springfox</groupId>
    <artifactId>springfox-swagger-ui</artifactId>
    <version>2.8.0</version>
    <scope>compile</scope>
    </dependency>
    <!--END Added for Swagger Dependency -->




    1. You need to have a Swagger config class ..



      @Configuration
      @EnableSwagger2
      public class SwaggerConfig extends WebMvcConfigurationSupport {



      @Bean
      public Docket productApi() {


      /* Swagger : For Particular Rest Service under somepackge, someEndpoint

      return new Docket(DocumentationType.SWAGGER_2).select()
      .apis(RequestHandlerSelectors.basePackage("com.abcdli.somepackge.controller"))
      .paths(PathSelectors.regex("/someEndpoint.*")).build();*/


      /* Swagger : Simple method for all the apis

      return new Docket(DocumentationType.SWAGGER_2).select()
      .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build();
      */

      /*
      Swagger : Simple method for all the apis under somepackage only
      */

      return new Docket(DocumentationType.SWAGGER_2).select()
      .apis(RequestHandlerSelectors.basePackage("com.abcdli.yourpackage.controller"))
      .paths(PathSelectors.any())
      .build()
      /*
      Swagger : metaInfo() is used for enrichment with details
      ApiInfo(title, description, version, termsOfServiceUrl, contactName, license, licenseUrl);
      */
      .apiInfo(metaInfo());



      }

      private ApiInfo metaInfo() {

      String description = ;


      return new ApiInfoBuilder()
      .title("YOUR APPLICATION NAME")
      .description(description)
      .version("1.0.0.1")
      .contact(new springfox.documentation.service.Contact("TEAM","www.mw.com","mw.abcd.com"))
      .build();


      }

      @Override
      protected void addResourceHandlers(ResourceHandlerRegistry registry) {
      registry.addResourceHandler("swagger-
      ui.html").addResourceLocations("classpath:/META-INF/resources/");

      registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
      }


      }




    3 . Now the Swagger Page is ready . Now need customize the controller , methods and models. This is very straight forward.



    /*
    Registering the RestAPI
    */
    @Api(value="YourController",description="some description")
    public class YourController {
    @RequestMapping(value = "/path", method = RequestMethod.POST,
    consumes = {
    "application/JSON" }, produces = { "application/JSON" })

    /*
    Registering the method
    */
    @ApiOperation(value="Adding a method",response=Response.class)
    public ResponseEntity<Response> addMethodDetails(
    @RequestBody modifyReq) {

    }




    1. You need provide access to these resources , if your API is secured with some authentication ..




      • //http.anonymous().disable(); [ anonymous ]


      • http.authorizeRequests()
        .antMatchers("/swagger-resources/",
        "swagger-resources/configuration/ui/*",
        "/swagger-ui.html
        ",
        "/webjars/**",
        "favicon.ico").permitAll();













    share|improve this question

























      0












      0








      0








      While I was implementing Swagger , I found lot of help from the communities/blogs , but in one place . So I a summarizing the critical ones, just to save time for others..



      1 . Need to include the dependencies..



              <!-- Added for Swagger Dependency -->
      <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger2</artifactId>
      <version>2.8.0</version>
      <scope>compile</scope>
      </dependency>
      <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger-ui</artifactId>
      <version>2.8.0</version>
      <scope>compile</scope>
      </dependency>
      <!--END Added for Swagger Dependency -->




      1. You need to have a Swagger config class ..



        @Configuration
        @EnableSwagger2
        public class SwaggerConfig extends WebMvcConfigurationSupport {



        @Bean
        public Docket productApi() {


        /* Swagger : For Particular Rest Service under somepackge, someEndpoint

        return new Docket(DocumentationType.SWAGGER_2).select()
        .apis(RequestHandlerSelectors.basePackage("com.abcdli.somepackge.controller"))
        .paths(PathSelectors.regex("/someEndpoint.*")).build();*/


        /* Swagger : Simple method for all the apis

        return new Docket(DocumentationType.SWAGGER_2).select()
        .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build();
        */

        /*
        Swagger : Simple method for all the apis under somepackage only
        */

        return new Docket(DocumentationType.SWAGGER_2).select()
        .apis(RequestHandlerSelectors.basePackage("com.abcdli.yourpackage.controller"))
        .paths(PathSelectors.any())
        .build()
        /*
        Swagger : metaInfo() is used for enrichment with details
        ApiInfo(title, description, version, termsOfServiceUrl, contactName, license, licenseUrl);
        */
        .apiInfo(metaInfo());



        }

        private ApiInfo metaInfo() {

        String description = ;


        return new ApiInfoBuilder()
        .title("YOUR APPLICATION NAME")
        .description(description)
        .version("1.0.0.1")
        .contact(new springfox.documentation.service.Contact("TEAM","www.mw.com","mw.abcd.com"))
        .build();


        }

        @Override
        protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-
        ui.html").addResourceLocations("classpath:/META-INF/resources/");

        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
        }


        }




      3 . Now the Swagger Page is ready . Now need customize the controller , methods and models. This is very straight forward.



      /*
      Registering the RestAPI
      */
      @Api(value="YourController",description="some description")
      public class YourController {
      @RequestMapping(value = "/path", method = RequestMethod.POST,
      consumes = {
      "application/JSON" }, produces = { "application/JSON" })

      /*
      Registering the method
      */
      @ApiOperation(value="Adding a method",response=Response.class)
      public ResponseEntity<Response> addMethodDetails(
      @RequestBody modifyReq) {

      }




      1. You need provide access to these resources , if your API is secured with some authentication ..




        • //http.anonymous().disable(); [ anonymous ]


        • http.authorizeRequests()
          .antMatchers("/swagger-resources/",
          "swagger-resources/configuration/ui/*",
          "/swagger-ui.html
          ",
          "/webjars/**",
          "favicon.ico").permitAll();













      share|improve this question














      While I was implementing Swagger , I found lot of help from the communities/blogs , but in one place . So I a summarizing the critical ones, just to save time for others..



      1 . Need to include the dependencies..



              <!-- Added for Swagger Dependency -->
      <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger2</artifactId>
      <version>2.8.0</version>
      <scope>compile</scope>
      </dependency>
      <dependency>
      <groupId>io.springfox</groupId>
      <artifactId>springfox-swagger-ui</artifactId>
      <version>2.8.0</version>
      <scope>compile</scope>
      </dependency>
      <!--END Added for Swagger Dependency -->




      1. You need to have a Swagger config class ..



        @Configuration
        @EnableSwagger2
        public class SwaggerConfig extends WebMvcConfigurationSupport {



        @Bean
        public Docket productApi() {


        /* Swagger : For Particular Rest Service under somepackge, someEndpoint

        return new Docket(DocumentationType.SWAGGER_2).select()
        .apis(RequestHandlerSelectors.basePackage("com.abcdli.somepackge.controller"))
        .paths(PathSelectors.regex("/someEndpoint.*")).build();*/


        /* Swagger : Simple method for all the apis

        return new Docket(DocumentationType.SWAGGER_2).select()
        .apis(RequestHandlerSelectors.any()) .paths(PathSelectors.any()) .build();
        */

        /*
        Swagger : Simple method for all the apis under somepackage only
        */

        return new Docket(DocumentationType.SWAGGER_2).select()
        .apis(RequestHandlerSelectors.basePackage("com.abcdli.yourpackage.controller"))
        .paths(PathSelectors.any())
        .build()
        /*
        Swagger : metaInfo() is used for enrichment with details
        ApiInfo(title, description, version, termsOfServiceUrl, contactName, license, licenseUrl);
        */
        .apiInfo(metaInfo());



        }

        private ApiInfo metaInfo() {

        String description = ;


        return new ApiInfoBuilder()
        .title("YOUR APPLICATION NAME")
        .description(description)
        .version("1.0.0.1")
        .contact(new springfox.documentation.service.Contact("TEAM","www.mw.com","mw.abcd.com"))
        .build();


        }

        @Override
        protected void addResourceHandlers(ResourceHandlerRegistry registry) {
        registry.addResourceHandler("swagger-
        ui.html").addResourceLocations("classpath:/META-INF/resources/");

        registry.addResourceHandler("/webjars/**").addResourceLocations("classpath:/META-INF/resources/webjars/");
        }


        }




      3 . Now the Swagger Page is ready . Now need customize the controller , methods and models. This is very straight forward.



      /*
      Registering the RestAPI
      */
      @Api(value="YourController",description="some description")
      public class YourController {
      @RequestMapping(value = "/path", method = RequestMethod.POST,
      consumes = {
      "application/JSON" }, produces = { "application/JSON" })

      /*
      Registering the method
      */
      @ApiOperation(value="Adding a method",response=Response.class)
      public ResponseEntity<Response> addMethodDetails(
      @RequestBody modifyReq) {

      }




      1. You need provide access to these resources , if your API is secured with some authentication ..




        • //http.anonymous().disable(); [ anonymous ]


        • http.authorizeRequests()
          .antMatchers("/swagger-resources/",
          "swagger-resources/configuration/ui/*",
          "/swagger-ui.html
          ",
          "/webjars/**",
          "favicon.ico").permitAll();










      spring-boot spring-mvc swagger






      share|improve this question













      share|improve this question











      share|improve this question




      share|improve this question










      asked Jan 3 at 12:41









      SUBHODiP GhoshSUBHODiP Ghosh

      265




      265
























          0






          active

          oldest

          votes












          Your Answer






          StackExchange.ifUsing("editor", function () {
          StackExchange.using("externalEditor", function () {
          StackExchange.using("snippets", function () {
          StackExchange.snippets.init();
          });
          });
          }, "code-snippets");

          StackExchange.ready(function() {
          var channelOptions = {
          tags: "".split(" "),
          id: "1"
          };
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function() {
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled) {
          StackExchange.using("snippets", function() {
          createEditor();
          });
          }
          else {
          createEditor();
          }
          });

          function createEditor() {
          StackExchange.prepareEditor({
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: true,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: 10,
          bindNavPrevention: true,
          postfix: "",
          imageUploader: {
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          },
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          });


          }
          });














          draft saved

          draft discarded


















          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54022508%2fspringboot-swagger-in-short%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes
















          draft saved

          draft discarded




















































          Thanks for contributing an answer to Stack Overflow!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid



          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function () {
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f54022508%2fspringboot-swagger-in-short%23new-answer', 'question_page');
          }
          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          Monofisismo

          Angular Downloading a file using contenturl with Basic Authentication

          Olmecas