- 基于java注释生成接口文档
- 注释支持扩展
- 接口框架支持扩展
- 默认支持markdown和离线/在线html等格式的文档
- 默认支持spring mvc规范
- 默认支持spring-boot直接内嵌启动
<!--加入maven依赖-->
<dependency>
<groupId>com.github.treeleafj</groupId>
<artifactId>spring-boot-starter-luzern</artifactId>
<version>1.0.0</version>
</dependency>
@Enableluzern //<--- 加上此注解以便启用luzern在线HTML文档
@SpringBootApplication
public class TestApplication {
public static void main(String[] args) {
SpringApplication.run(TestApplication.class, args);
}
}
#在application.properties配置项目源码的位置,直接在项目里启动时,如果是单模块的maven项目,默认可以不配置
luzern.enable=true #是否启动luzern,默认是true,因为可以不填
luzern.sourcePath=luzern-spring-test/src/main/java #源码路径,多个时用英文逗号隔开
luzern.title=用户中心接口文档 #用于配置文档页面标题
luzern.version=1.0 #标识接口文档的版本号
以上配置就都写好了
跟着随便写几个Controller作为Demo接口,便于直接浏览生成效果:
/**
* 用户模块
*
* @author leaf
* @date 2017-03-03 10:11
*/
@Controller
@RequestMapping("api/user")
public class UserController {
/**
* 登录
*
* @param username 用户名|必填
* @param password 密码
* @return 当前登录用户的基本信息
* @resp code 返回码(0000表示登录成功,其它表示失败)|string|必填
* @resp msg 登录信息|string
* @resp username 登录成功后返回的用户名|string
*/
@ResponseBody
@PostMapping("login")
public Map<String, String> login(String username, String password) {
Map<String, String> model = new HashMap<>();
model.put("code", "0000");
model.put("msg", "登录成功");
model.put("username", username);
return model;
}
/**
* 用户注册
*
* @param user :username 用户名|必填
* @param user :password 密码
* @return 注册后生成的用户的基本信息
* @respbody {"id":"123","password":"123456","username":"admin"}
* @title 注册
* @see User
* @resp score 分数
*/
@ResponseBody
@RequestMapping(value = "register", method = {RequestMethod.POST, RequestMethod.PUT})
User register(com.github.hopedc.luzern.test.vo.User user, @RequestParam(value = "abc", required = false)List<MultipartFile> list) {
user.setId(UUID.randomUUID().toString());
return user;
}
}
直接启动项目, 敲入地址: http://localhost:8080/luzern/index.html
支持html:
@Test
public void buildHtml() throws Exception {
//生成离线的HTML格式的接口文档
String userDir = System.getProperty("user.dir");
FileOutputStream out = new FileOutputStream(new File(userDir, "api.html"));
luzern luzern = new luzern(userDir + "/src/main/java/org/treeleafj", new SpringWebFramework());
luzern.build(out, new HtmlForamt());
}
也支持markdown:
@Test
public void buildMarkdown() {
//生成离线的Markdown格式的接口文档
ByteArrayOutputStream out = new ByteArrayOutputStream();
String rootDir = System.getProperty("user.dir");
luzern luzern = new luzern(rootDir + "/src/main/java/org/treeleafj", new SpringWebFramework());
luzern.build(out, new MarkdownFormat());
System.out.println(out.toString());
}
tip:生产环境不推荐开启此文档,所以配置文件中配置好:
luzern.enable=false