Swagger与knife4j的不同之处
下面写法简单明了不含糊直接干货走起:
1、程序员一般写接口文档比较麻烦,首先是访问路径,请求方式,请求参数,请求列表,请求参数实例,返回结果,返回结果类型,返回结构,返回结构实例,返回参数列表,返回状态码列表等待等。。。没完没了的太多,搞人心态
结果就有了Swagger在线文档,这个文档需要注意的是:3.0版本的前后输入的后缀差别,前→swagger-ui.html,后→swagger-ui/index.html,而且版本的界面是这样的:
这样的: 虽然已经很明细了,但如果在后台新增一些东西,难免会造成页面个别参数(
Example Value)的缺失,还需要手动填写,确实有点蓝瘦香菇;
2、现在发现一个比swagger2更好用的,直接可以下载pdf,word,html,md文档,是不是很高级呢?虽然也是初用,记录下让大家也新鲜新鲜,这个前提也是swagger中的:knife4j
他的界面是这样的:
这样的:
以及这样的:
导出的md是这样的:
是不是给人眼前一亮,回头前端再来跟咱们后端要测试代码的时候,终于可以硬气一点这是文档,拿走不谢,嘿嘿
3、聊了这么多大家是不是流口水了呢!直接上代码:一般knife4j属于common公共类的,所以需要在common中创建一个knife4j(包名随便写,自己看得懂就行)然后就看你的C/V大法是不是功力深厚了,要声明的是:swagger与knife4j之间的区别在于这个注解:@EnableKnife4j
import com.github.xiaoymin.knife4j.spring.annotations.EnableKnife4j;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.builders.RequestHandlerSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;
@Configuration
@EnableSwagger2
@EnableKnife4j
public class SwaggerConfiguration {
@Bean
public Docket buildDocket() {
return new Docket(DocumentationType.SWAGGER_2)
.apiInfo(buildApiInfo())
.select()
.apis(RequestHandlerSelectors.basePackage("com.usian"))
.paths(PathSelectors.any())
.build();
}
private ApiInfo buildApiInfo() {
Contact contact = new Contact("程序员", "", "");
return new ApiInfoBuilder()
.title("头条-平台管理API文档Knife4j")
.description("平台管理服务api")
.contact(contact)
.version("1.0.0").build();
}
}
common公共类已经完成了,那么该继承公共类的项目进行扫描了,但是这两个包相差的有点远,如何让admin扫描到common里面的knife4j呢,我们需要在admin中创建一个config包,然后创建一个knife4j的实体类,然后将这个类上方添加:@configuration注解,在添加一个包扫描:@ComponentScan("com.包名.knife4j"),注:knife4j在common中的绝对路径
完整版的是这样的,然后就可以启动项目了,访问地址:doc.html
赶紧去试试吧
