博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
如何在SwaggerAPI中添加统一授权认证
阅读量:4044 次
发布时间:2019-05-24

本文共 2897 字,大约阅读时间需要 9 分钟。

效果图

在这里插入图片描述

配置

pom文件添加依赖

io.swagger
swagger-annotations
1.5.19
io.springfox
springfox-swagger2
2.9.2
io.springfox
springfox-swagger-ui
2.9.2

创建配置文件

在Application文件的同级目录或同级下的子集目录中创建swaggerconfig.java配置文件

package com.project.config; // 项目的配置包下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.ApiKey;import springfox.documentation.service.AuthorizationScope;import springfox.documentation.service.SecurityReference;import springfox.documentation.spi.DocumentationType;import springfox.documentation.spi.service.contexts.SecurityContext;import springfox.documentation.spring.web.plugins.Docket;import springfox.documentation.swagger2.annotations.EnableSwagger2;import static com.google.common.collect.Lists.newArrayList;import java.util.List;/**  * swagger配置  *   * @Author seven  * @Date 9:17 19/12/10*/@Configuration@EnableSwagger2public class Swagger2 {
@Bean public Docket createRestApi() {
return new Docket(DocumentationType.SWAGGER_2) .apiInfo(apiInfo()) .select() .apis(RequestHandlerSelectors.basePackage("com.project.provider.controller")) .paths(PathSelectors.any()) .build() .securitySchemes(securitySchemes()) .securityContexts(securityContexts()); } private List
securitySchemes() {
return newArrayList( new ApiKey("Authorization","Authorization","header")); } private List
securityContexts() {
return newArrayList( SecurityContext.builder() .securityReferences(defaultAuth()) .forPaths(PathSelectors.any()) .build() ); } List
defaultAuth() {
AuthorizationScope authorizationScope = new AuthorizationScope("global","accessEverything"); AuthorizationScope[] authorizationScopes = new AuthorizationScope[1]; authorizationScopes[0] = authorizationScope; return newArrayList( new SecurityReference("Authorization",authorizationScopes)); } private ApiInfo apiInfo() {
return new ApiInfoBuilder() .title("测试项目API") .description("") .termsOfServiceUrl("") .version("1.0") .build(); }}

使用

点击Authorize按钮

在这里插入图片描述

输入Token,点击Authorize按钮

在这里插入图片描述

效果如下
在这里插入图片描述
点击Close,测试方法即可
点击Logout,退出

转载地址:http://quzci.baihongyu.com/

你可能感兴趣的文章
python_configparser(解析ini)
查看>>
selenium学习资料
查看>>
<转>文档视图指针互获
查看>>
从mysql中 导出/导入表及数据
查看>>
HQL语句大全(转)
查看>>
几个常用的Javascript字符串处理函数 spilt(),join(),substring()和indexof()
查看>>
javascript传参字符串 与引号的嵌套调用
查看>>
swiper插件的的使用
查看>>
layui插件的使用
查看>>
JS牛客网编译环境的使用
查看>>
9、VUE面经
查看>>
关于进制转换的具体实现代码
查看>>
Golang 数据可视化利器 go-echarts ,实际使用
查看>>
mysql 跨机器查询,使用dblink
查看>>
mysql5.6.34 升级到mysql5.7.32
查看>>
dba 常用查询
查看>>
Oracle 异机恢复
查看>>
Oracle 12C DG 搭建(RAC-RAC/RAC-单机)
查看>>
Truncate 表之恢复
查看>>
Oracle DG failover 后恢复
查看>>