内容简介:接口文档生成器指的是写好了 API 接口 之后,让前台开放人员(包括不限于 H5 前端、iOS/Android 客户端、小程序等)调用接口时的文档。个人比较主张“代码即文档”,即文档编写在源码之中。先全网选型了一下,发现适合 Java 的有下面几种开源的方案。看来也只是 Swagger 比较合适。然而 Swagger 这货也不简单。首先是搞 Java 言必称 Spring,所以文档工具也首推 for Spring 的(很文章介绍 Swagger 的一个插件,实际 Swagger 真身是 Swagger C
接口文档生成器指的是写好了 API 接口 之后,让前台开放人员(包括不限于 H5 前端、iOS/Android 客户端、小程序等)调用接口时的文档。个人比较主张“代码即文档”,即文档编写在源码之中。
先全网选型了一下,发现适合 Java 的有下面几种开源的方案。
- Swagger ,也就是本文的主角,实际情形比较复杂,下面再说
- apidoc.js ,node.js 方案,通过注释写文档,而不是真正代码,舍弃之
- RAP ,淘宝出品,没深入了解
- Api2Doc2 ,国人出品,for Java 的,励志做 Java 届最好用的文档工具,不过听过生成的文档还要 SpringBoot 来跑,太重了,舍弃之。
看来也只是 Swagger 比较合适。然而 Swagger 这货也不简单。首先是搞 Java 言必称 Spring,所以文档 工具 也首推 for Spring 的(很文章介绍 Swagger 的一个插件,实际 Swagger 真身是 Swagger Core)。我不是搞 Spring 的就不能用 Swagger 呢?肯定不是, Swagger 不是 Spring 专属的,只不过 Spring 一家独大,所以网上资料也净是它的,连墙外的 google 也是……
刨英文吧,官方的文档是唯一的指南了……
第二个问题,Swagger 本身的问题,这货通过注解实现文档,旧版的是自己的注解,但后来呢,成立的一个什么 Open API 组织还是什么标准,针对文档服务提出新的开放规范。好吧~旧的注解通通要变身了,所以呢,现在很多文章的停留在旧版的注解上。新版的还是要看官方文档。
那咱就用新版吧~
可是怎么用呢?Swagger 这货介绍新版文章几乎为 0,官文又写得云里雾里,我悲苦逼呐~说要 jetty 服务器,然后我的 maven 下载 jar 又文件损坏,搞一大轮,发现 tomcat 7 不行要 tomcat 8,shit 几乎快放弃。
抱着这种想法,通常是柳暗花明又一炮的时候,——我发现它的 simple 项目,都齐备着呢,不同开源项目都有,我想要的是最普通的 Servlet 那个,也有,于是 checkout 下来跑一下,齐活了。
使用说明
首先,Swagger 是这样子的:
- 通过注解编写文档,这很科学,没毛病
- 除了自己的注解,还能辨识来自 javax.ws.rs 即 JAX-RS(Java API for RESTful Web Services) 的注解。如果你的接口项目是用 JAX-RS,那就完美了;如果你不知道这是啥,还是先百度下。反正就是 Java 的一个标准,我们用的是它注解。
- 官文说要 Jetty 但 tomcat 也行,不过因为一个 jar 包版本问题,得 Tomcat 8 才行
- 实际引用的是 Swagger Core,for 普通 Java 项目的。如果你用 Spring Boot 这里跑错片场了。
- Swagger Core 能解析代码的文档部分,形成 YAML、JSON 定义文件,这是给机器看不是人看的。不能直接渲染最终的 HTML/Markdown,要渲染出漂亮的文档, 那是 Swagger UI 干的事情。所以得先导出定义文件再弄文档页面。
其次,是一些相关有用的网址:
- Swagger Core 项目主页 https://github.com/swagger-api/swagger-core
- 官文(洋文) https://github.com/swagger-api/swagger-core/wiki/Swagger-2.X—Getting-started
- 样例项目 https://github.com/swagger-api/swagger-samples/tree/2.0/java/java-jaxrs2-openapiservlet
普通 Servlet 样例
官方样例的“纯度”不是很够,参杂其他多余的依赖,于是我做了一个普通 Java Web 项目来跑,清爽。
1、新建 Web 项目并将其转为 Maven 项目,添加下面依赖。
<dependency> <groupId>io.swagger.core.v3</groupId> <artifactId>swagger-jaxrs2</artifactId> <scope>compile</scope> <version>2.0.4</version> </dependency> <!-- 做 RESTful 接口的注解 --> <dependency> <groupId>javax.ws.rs</groupId> <artifactId>javax.ws.rs-api</artifactId> <version>2.1</version> </dependency>
2、修改 web.xml,增加一个 servlet,访问生成的文档定义文件。
<servlet> <!-- 生成接口文档服务 --> <servlet-name>OpenApi</servlet-name> <servlet-class>io.swagger.v3.jaxrs2.integration.OpenApiServlet</servlet-class> <init-param> <param-name>openApi.configuration.resourcePackages</param-name> <param-value>io.swagger.sample.resource</param-value><!-- 指定扫描的包 --> </init-param> <!-- 另外可以在 classpath 中引入配置文件 openapi-configuration.json or openapi-configuration.yaml --> <!-- 还可以在下面配置中指明配置文件的位置 --> <!-- <init-param> <param-name>openApi.configuration.location</param-name> <param-value>/openapi-configuration.json</param-value> </init-param> --> <load-on-startup>2</load-on-startup> </servlet> <servlet-mapping> <servlet-name>OpenApi</servlet-name> <url-pattern>/openapi/*</url-pattern> </servlet-mapping>
3、写一个测试,在 java 中添加 Swagger 注解,写上你的文档,
注解很多的,看你怎么写文档。
4、运行起来,就是 Run Server,Swagger 会在 Tomcat 启动时解析文档。启动后,访问 Servlet,如 http://localhost:8080/test_doc/openapi/openapi.json ,如无意外会是:
好了,这就得到文档的定义文件。
接着就是生成漂亮的 html,可俺还不会,没研究出来 Swagger-UI~唉.
另外可以在 Swagger Editor http://editor.swagger.io/ 中预览下,就是把定义文件的内容粘贴到 editor 里面去。
以上所述就是小编给大家介绍的《Swagger 2(Open API v3.0) Java 文档生成指南(上)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 在 Laravel 中集成 API 文档生成器扩展包为 Dingo API 接口生成文档
- 使用Sphinx生成/管理文档
- Java 生成 PDF 文档
- 文档生成器 mkdocs
- Doxygen 3 发布,文档生成工具
- 如何使用 sphinx 来生成代码文档
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
尽在双11:阿里巴巴技术演进与超越
阿里巴巴集团双11技术团队 / 电子工业出版社 / 2017-4 / 79
“双 11”,诞生于杭州,成长于阿里,风行于互联网,成就于新经济,贡献于全世界。 从 2009 年淘宝商城起,双 11 已历经八年。每年的双 11 既是当年的结束,又是走向未来的起点。技术的突破创新,商业模式的更替交互,推动着双 11 迈步向前。 《尽在双11——阿里巴巴技术演进与超越》是迄今唯一由阿里巴巴集团官方出品、全面阐述双 11 八年以来在技术和商业上演进和创新历程的书籍。内容......一起来看看 《尽在双11:阿里巴巴技术演进与超越》 这本书的介绍吧!