生成文档页面

easyopen提供一个简单的api文档查看页面,类似于swagger,基于注解功能来生成文档页面。生成的文档页面可以查看参数、结果说明,也可以进行模拟请求。对于前后端分离的项目来说会很有帮助。文档界面如下图所示:

输入图片说明

左边的树形菜单对应文档名称,点击树可前往查看对应的接口说明。点击请求按钮可以发起请求进行测试。可修改业务参数中的值进行测试。

下面来讲解文档注解的使用方法。

文档页面默认是关闭的,需要在ApiConfig中设置

  1. apiConfig.setShowDoc(true);// 为true开启文档页面。

接下来对获取商品接口设置文档信息:

  1. @Api(name = "goods.get")
  2. public Goods getGoods(GoodsParam param) {
  3. ...
  4. return goods;
  5. }

设置文档注解

在接口方法上添加一个@ApiDocMethod注解。

  1. @Api(name = "goods.get")
  2. @ApiDocMethod(description="获取商品") // 文档注解,description为接口描述
  3. public Goods getGoods(GoodsParam param) {
  4. ...
  5. return goods;
  6. }

设置参数注解

  • 方式1:直接在@ApiDocMethod注解中申明params属性

    1. @Api(name = "goods.get")
    2. @ApiDocMethod(description = "获取商品", params = {
    3. @ApiDocField(name = "id", dataType = DataType.INT, example = "1"),
    4. @ApiDocField(name = "goodsName", dataType = DataType.STRING, description = "商品名称", example = "iPhone6"),
    5. })
    6. public Goods getGoods(GoodsParam param) {
    7. ...
    8. return goods;
    9. }
  • 方式2:在实体类的字段上申明@ApiDocField注解
    进入GoodsParam类,使用@ApiDocField注解

  1. public class GoodsParam {
  2. @ApiDocField(description = "商品名称", required = true, example = "iphoneX")
  3. private String goods_name;
  4. // 省略 get set
  5. }

@ApiDocField注解用来定义字段信息,@ApiDocField注解定义如下

  1. /**
  2. * 字段描述
  3. */
  4. String description() default "";
  5. /**
  6. * 字段名
  7. */
  8. String name() default "";
  9. /**
  10. * 数据类型,int string float
  11. * @return
  12. */
  13. DataType dataType() default DataType.STRING;
  14. /**
  15. * 是否必填
  16. */
  17. boolean required() default false;

注:方式1,方式2同时存在的情况下优先使用方式1

设置返回结果注解

同样,在Goods类中设置@ApiDocField

  1. public class Goods {
  2. @ApiDocField(description = "id")
  3. private Long id;
  4. @ApiDocField(description = "商品名称")
  5. private String goods_name;
  6. @ApiDocField(description = "价格", dataType = DataType.FLOAT)
  7. private BigDecimal price;
  8. // 省略 get set
  9. }

到此已经设置完毕了,可以访问url进行预览

文档页面URL

文档页面的url格式为:apiUrl + “/doc”。如:apiUrl为http://localhost:8080/api/v1,那么文档页面就是:[http://localhost:8080/api/v1/doc](http://localhost:8080/api/v1/doc)

List返回

如果接口方法返回一个List<T>,设置方式如下

  1. @Api(name = "goods.list", version = "2.0")
  2. @ApiDocMethod(description="获取商品列表"
  3. ,results={@ApiDocField(description="商品列表",name="list", elementClass=Goods.class)}
  4. )
  5. public List<Goods> listGoods(GoodsParam param) {
  6. }

elementClass对应List中的元素类型

设置文档密码(v1.8.5)

  1. apiConfig.setDocPassword("doc123"); // 设置文档页面密码

设置完成后,需要输入密码才能访问文档页面,可配合线上联调,排错。

修改文档页返回字段名(v1.8.5)

文档页面默认返回字段名为code,msg,data。可在IndexController中重写processDocVelocityContext()定义

  1. @Override
  2. protected void processDocVelocityContext(VelocityContext context) {
  3. context.put("code_name", "errCode");
  4. context.put("code_description", "状态值,\"0\"表示成功,其它都是失败");
  5. context.put("msg_name", "errMsg");
  6. context.put("msg_description", "错误信息,出错时显示");
  7. context.put("data_name", "respData");
  8. context.put("data_description", "返回的数据,没有则返回{}");
  9. }

第三方类返回

如果有个一个PageInfo<T>类,是第三方jar中的,没办法对其修改,那要如何对它里面的属性编写对应文档呢。

PageInfo<T>类内容如下:

  1. // 假设这是jar中的类,没法修改。但是要对其进行文档生成
  2. public class PageInfo<T> {
  3. private int pageIndex;
  4. private int pageSize;
  5. private long total;
  6. // 省略 get set
  7. }

我们可以显式的声明字段信息:

  1. @Api(name = "goods.pageinfo", version = "1.0")
  2. @ApiDocMethod(description="获取商品列表"
  3. ,results={@ApiDocField(name="pageIndex",description="第几页",dataType=DataType.INT,example="1"),
  4. @ApiDocField(name="pageSize",description="每页几条数据",dataType=DataType.INT,example="10"),
  5. @ApiDocField(name="total",description="每页几条数据",dataType=DataType.LONG,example="100"),
  6. @ApiDocField(name="rows",description="数据",dataType=DataType.ARRAY,elementClass=Goods.class),}
  7. )
  8. public PageInfo<Goods> pageinfo(GoodsParam param) {
  9. }

文档模型复用

如果多个接口都返回PageInfo<Goods>,需要复制黏贴大量的注解,改一个地方需要改多个接口,无法达到复用效果。我们可以新建一个GoodsPageVo继承PageInfo,然后把文档注解写在类的头部,这样可以达到复用效果。

  1. @ApiDocBean(fields = {
  2. @ApiDocField(name="pageIndex",description="第几页",dataType=DataType.INT,example="1"),
  3. @ApiDocField(name="pageSize",description="每页几条数据",dataType=DataType.INT,example="10"),
  4. @ApiDocField(name="total",description="每页几条数据",dataType=DataType.LONG,example="100"),
  5. @ApiDocField(name="rows",description="商品列表",dataType=DataType.ARRAY,elementClass=Goods.class),
  6. })
  7. public class GoodsPageVo extends PageInfo<Goods> {
  8. }
  1. @Api(name = "goods.pageinfo", version = "2.0")
  2. @ApiDocMethod(description="获取商品列表",resultClass=GoodsPageVo.class)
  3. public PageInfo<Goods> pageinfo2(GoodsParam param) {
  4. }

使用resultClass=GoodsPageVo.class指定返回结果类型即可。

更改文档显示位置(v1.9.1)

可以使用order属性来指定文档显示位置,值越小越靠前

  1. @ApiDoc(value = "文档demo,参考DocDemoApi.java", order = 1)
  2. @ApiDocMethod(description = "第一个", order = 1 // 指定了order,优先按这个值排序
  3. )
  4. 若不指定order,则按接口名排序