美文网首页javaWeb学习java
Swagger配置鉴权token

Swagger配置鉴权token

作者: 李征兵 | 来源:发表于2019-12-26 18:54 被阅读0次

    众所周知swagger在API文档生成及测试方面非常方便,但是很多的API调用都需要用到token验证,本文就介绍两中自动添加token的方法。以下的配置代码都是在swagger config类里边。

    对每个API都添加header字段

    这个方案的优点是每个API测试的时候都可以分别设置token,缺点是大量重复输入token字段,如果API数量众多或者写入header的字段多就很麻烦。

        @Bean
        public Docket createRestApi() {
            return new Docket(DocumentationType.SWAGGER_2)
                    .apiInfo(apiInfo())
                    .select()
                    .apis(RequestHandlerSelectors.basePackage("com.platform.middle.user.base.web"))
                    .paths(PathSelectors.any())
                    .build()
                    .globalOperationParameters(defaultHeader())
                    ;
        }
        private static List<Parameter> defaultHeader(){
            ParameterBuilder appType = new ParameterBuilder();
            appType.name("app-type").description("应用类型").modelRef(new ModelRef("string")).parameterType("header").required(false).build();
            ParameterBuilder appToken = new ParameterBuilder();
            appToken.name("app-token").description("令牌").modelRef(new ModelRef("string")).parameterType("header").required(false).build();
            List<Parameter> pars = new ArrayList<>();
            pars.add(appType.build());
            pars.add(appToken.build());
            return pars;
        }
    

    重点是在原先swagger的Docket对象后面添加globalOperationParameters方法。运行的效果如图:

    认证用的token作为API的header类型输入参数

    全站统一header设置

    这种方案就简化了第一种方案,在swagger UI上出现一个Authorize按钮,一次输入header参数,全站使用。

        @Bean
        public Docket createRestApi() {
            return new Docket(DocumentationType.SWAGGER_2)
                    .apiInfo(apiInfo())
                    .select()
                    .apis(RequestHandlerSelectors.basePackage("com.platform.middle.common.fastdfs.web"))
                    .paths(PathSelectors.any())
                    .build()
                    .securitySchemes(unifiedAuth())
                    ;
        }
        private static List<ApiKey> unifiedAuth() {
            List<ApiKey> arrayList = new ArrayList();
            arrayList.add(new ApiKey("app-type", "app-type", "header"));
            arrayList.add(new ApiKey("app-token", "app-token", "header"));
            return arrayList;
        }
    

    重点是在原先swagger的Docket对象后面添加securitySchemes方法。运行的效果如图:

    统一header字段设置
    这样就在每次调用API的时候把app-token、app-type作为header内容发送给服务端。服务端就可以用这些字段进行必要的认证。

    相关文章

      网友评论

        本文标题:Swagger配置鉴权token

        本文链接:https://www.haomeiwen.com/subject/qteloctx.html