很高兴 smalldoc 可以帮助 Java Web 开发人员解决文档书写的麻烦,将大家从 swagger 的繁琐注解中解救出来,也感谢使用者提出的 issues 帮助 smalldoc 变得更完善更便捷。java
smalldoc-2.3.1根据 issues更新以下:react
source-paths 默认已经给出当前项目源码路径(即,引入该smalldoc依赖的项目的源码路径 —— System.getProperty("user.dir")
, 2.3.1
修复了不配置路径的空指针错误。git
packages 配置Controller类
所在的包,会自动递归它们子包。若是没有指定,默认为/
,将扫描源码路径下全部包,建议给出指定包名,提高解析速度。github
不管你的返回对象有几层,均可以显示在返回参数表格中,以下图 c#
*Mapping注解
解析异常。java.lang.ClassCastException: java.lang.Boolean cannot be cast to [Lcom.sun.javadoc.AnnotationValue;
复制代码
@*
表示必须,不然为可选参数。包括基本类型,基本类型的包装类型,字符串,以及它们的数组,List,Set,同时还有一些库类型
—— 例如 File , MultipartFile@{f1[*],[f2[*],...]}
这种形式来写,要么代替整个注释,要么放在注释最后。
f
表示实体类的某个字段名,经过它 ,smalldoc 能够去你的实体类源码中搜寻参数的注释。*
表示必须,不然为可选参数。@{}
内,该字段将不会做为参数。@
以前还有其它注释内容,将被忽略。示例以下。数组
优化事后的参数名支持复杂数据结构,好比关联对象,关联集合,Set,List或数组,可直接做为实际参数名进行接口调用。浏览器
示例代码antd
/** * 测试接口 * @param file 文件 * @param bb saddas * @param cc CCCC * @param pp h哈哈是@* * @param cca 擦擦擦黑@{authorId*} * @param content 内容@* * @param oaCopyArray @{authorId*,originalArticleId,categoryId*,paragraph.content} * @param oaCopy @{authorId*,originalArticleId,categoryId*,paragraph.content} * @return data-草稿ID */
@RequestMapping("test_path/action2")
public Result<Long> test(MultipartFile file, Long[] bb , Long cc, List<String> pp, String content, List<OriginalArticleCopy> cca, OriginalArticleCopy[] oaCopyArray, OriginalArticleCopy oaCopy, HttpServletRequest request) {
return null;
}
复制代码
文档显示 数据结构
若是你的注释不规范,没法生成合理文档,smalldoc 将打印警告或直接提示异常app
最初的 smalldoc-antd-react-ui 【https://github.com/liuhuagui/smalldoc-antd-react-ui】,采用 React+Fetch
的形式得到文档结构,新版本改用 React+模板引擎
写法,使支持离线文档,你只须要在浏览器中打开文档UI界面,而后 Ctrl+S
保存离线文件。