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

赶紧去试试吧

经验分享 程序员 微信小程序 职场和发展