swagger-ui 系統配置過程(基於spring+springmvc+swagger+springfox配置 web-api 管理系統)


web工程部分框架信息:spring springmvc swagger springfox maven

參考文檔:
https://www.cnblogs.com/exmyth/p/7183753.html
https://www.cnblogs.com/arctictern/p/7498838.html
https://my.oschina.net/wangmengjun/blog/907679
http://springfox.github.io/springfox/docs/current/


pom.xml 對於 swagger-ui 的依賴

        <!-- https://mvnrepository.com/artifact/com.mangofactory/swagger-springmvc --> <dependency> <groupId>com.mangofactory</groupId> <artifactId>swagger-springmvc</artifactId> <version>0.9.5</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger2</artifactId> <version>2.7.0</version> </dependency> <!-- https://mvnrepository.com/artifact/io.springfox/springfox-swagger-ui --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-swagger-ui</artifactId> <version>2.7.0</version> </dependency> <!-- https://mvnrepository.com/artifact/io.springfox/springfox-petstore --> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-petstore</artifactId> <version>2.7.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-data-rest</artifactId> <version>2.7.0</version> </dependency> <dependency> <groupId>io.springfox</groupId> <artifactId>springfox-bean-validators</artifactId> <version>2.7.0</version> </dependency> <!-- https://mvnrepository.com/artifact/com.google.guava/guava --> <dependency> <groupId>com.google.guava</groupId> <artifactId>guava</artifactId> <version>23.4-jre</version> </dependency> <!-- https://mvnrepository.com/artifact/org.apache.maven.plugins/maven-javadoc-plugin --> <dependency> <groupId>org.apache.maven.plugins</groupId> <artifactId>maven-javadoc-plugin</artifactId> <version>3.0.0</version> </dependency>

工程結構(僅作為參考)

配置步驟如下:

1、創建 swagger 的配置類(如果要自定義一些內容,請參考官網 API 的描述)

@Configuration // 這是控制開關 @EnableSwagger2 // 這是用了 swagger2 @EnableWebMvc // 這是因為工程用的 springmvc @ComponentScan(basePackages = {"controller"}) //這里也許可以不用,暫沒去求證 public class SwaggerConfig { /** * Every Docket bean is picked up by the swagger-mvc framework - allowing for multiple swagger groups i.e. same code base multiple swagger resource listings. */ @Bean public Docket customDocket() { return new Docket(DocumentationType.SWAGGER_2) .select() //select()函數返回一個ApiSelectorBuilder實例用來控制哪些接口暴露給Swagger來展現 .apis(RequestHandlerSelectors.any()) //掃描指定包內所有Controller定義的Api,並產生文檔內容(除了被@ApiIgnore指定的請求)。 .paths(PathSelectors.any()) .build() .apiInfo(apiInfo()); //用來創建該Api的基本信息(這些基本信息會展現在文檔頁面中) } private ApiInfo apiInfo() { return new ApiInfoBuilder().title("Spring-mvc中使用Springfox集成Swagger2構建APIs").build(); } }

2、在 spring-mvc.xml 中添加掃描文件的信息

    <!-- Enables swgger ui --> <bean class="swagger.swaggerConfig.SwaggerConfig" /> <!-- 這里其實是為了解決靜態資源訪問的問題, 這是一種解決方式 --> <mvc:default-servlet-handler/>

3、在 spring-mvc的攔截器做處理,即在 web.xml 中追加

 <!-- springMVC核心配置 --> <servlet> <servlet-name>dispatcherServlet</servlet-name> <servlet-class>org.springframework.web.servlet.DispatcherServlet</servlet-class> <init-param> <param-name>contextConfigLocation</param-name> <!--spingMVC的配置路徑 --> <param-value>classpath:springmvc/spring-mvc.xml</param-value> </init-param> <load-on-startup>1</load-on-startup> </servlet> <!-- 攔截設置 --> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>*.do</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>default</servlet-name> <url-pattern>/swagger-ui.html</url-pattern> </servlet-mapping> <!--<servlet-mapping>--> <!--<servlet-name>default</servlet-name>--> <!--<url-pattern>*.png</url-pattern>--> <!--</servlet-mapping>--> <!--<servlet-mapping>--> <!--<servlet-name>default</servlet-name>--> <!--<url-pattern>*.js</url-pattern>--> <!--</servlet-mapping>--> <!--<servlet-mapping>--> <!--<servlet-name>default</servlet-name>--> <!--<url-pattern>*.css</url-pattern>--> <!--</servlet-mapping>--> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/</url-pattern> </servlet-mapping> <servlet-mapping> <servlet-name>dispatcherServlet</servlet-name> <url-pattern>/v2/api-docs</url-pattern> </servlet-mapping>

4、從https://github.com/swagger-api/swagger-ui 獲取其所有的 dist 目錄下東西放到需要集成的項目里

5、並打開復制過來的 index.html,修改 url

6、再在 spring-mvc.xml 中追加資源映射

    <mvc:resources mapping="*.html" location="apidoc/resources"/> <mvc:resources mapping="/**" location="apidoc/"/> <mvc:resources mapping="/webjars/**" location="classpath:/META-INF/resources/webjars"/> <mvc:resources mapping="swagger-ui.html" location="classpath:/META-INF/resources/" />

此時 spring-mvc.xml 看起來可能就像這樣:


注意下述內容最好保持一致(因為我也沒花時間去求解,之前因為一些處理,訪問時遇到了"base URL......"吧啦吧啦的模態框)



7、啟動運行成功后,訪問地址 http://localhost:8080/swagger-ui.html
看起來像這樣子:


個人目前對於 swagger 的用途(優缺點)理解

優點

  • 1、不用在 coding 之后再去寫接口文檔,可以實時同步更新
  • 2、不需要重復造輪子,寫解析器(當然定制化的會輕便靈活得多)
  • 3、可以用於后台的 web 接口的快速調試
  • 4、有配套的工具來支撐擴展(見 swagger 的官網 tools 欄目)

缺點

    • 1、有學習成本(如環境配置、注解使用等)
    • 2、可能會和真實開發的工程存在組件的沖突
    • 3、(最明顯的)工作量可能會增加,這個需要開發崗的慎重評估。比如非標准的 restful api設計;工程的復雜度設計如 DTO 完全就是對應 BO 時,需要拆成標准的設計;API 編寫的工作量受框架約束等等
    • 4、文檔界面雖美觀,但是閱讀性不一定直觀
    • 5、沒有自研的工具給力,對於測試工程師來說需要考慮使用 swagger 后解決方案
    • 6、工程之間是隔離的


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM