feat():增加鉴权

master
86191 2024-08-04 16:32:21 +08:00
parent f46543bb47
commit e626cf6271
1 changed files with 43 additions and 1 deletions

View File

@ -1,11 +1,16 @@
package com.muyu.common.api.doc.config;
import io.swagger.v3.oas.models.Components;
import io.swagger.v3.oas.models.ExternalDocumentation;
import io.swagger.v3.oas.models.OpenAPI;
import io.swagger.v3.oas.models.info.Info;
import io.swagger.v3.oas.models.security.SecurityRequirement;
import io.swagger.v3.oas.models.security.SecurityScheme;
import org.springdoc.core.customizers.GlobalOpenApiCustomizer;
import org.springframework.beans.factory.annotation.Value;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.http.HttpHeaders;
@Configuration
public class SpringDocConfig {
@ -29,6 +34,43 @@ public class SpringDocConfig {
public OpenAPI springShopOpenAPI() {
return new OpenAPI()
.info(info())
.externalDocs(externalDocumentation());
.externalDocs(externalDocumentation())
//配置全局鉴权参数-Autoorize
.components(new Components()
.addSecuritySchemes(HttpHeaders.AUTHORIZATION,
new SecurityScheme()
.name(HttpHeaders.AUTHORIZATION)
.type(SecurityScheme.Type.APIKEY)
.in(SecurityScheme.In.HEADER)
.scheme("bearer")
.bearerFormat("JWT")
)
);
}
@Bean
public GlobalOpenApiCustomizer globalOpenApiCustomizer(){
return openApi -> {
//全局添加鉴权参数
if (openApi.getPaths() != null){
openApi.getPaths().forEach((s,pathItem)->{
//登录接口/验证码不需要添加鉴权参数
if (s.equals("/login") || s.equals("code") || s.equals("/register")){
return;
}
//接口添加鉴权参数
pathItem.readOperations()
.forEach(operation ->
operation.addSecurityItem(new SecurityRequirement().addList(HttpHeaders.AUTHORIZATION))
);
});
}
};
}
}