SpringDocConfiguration

本文介绍了SpringDocConfiguration类如何在SpringBoot应用中集成Swagger,利用Nacos的DiscoveryClient动态获取服务实例的SwaggerURL,实现在API文档更新时自动注册和刷新。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

import com.alibaba.nacos.client.naming.event.InstancesChangeEvent;
import com.alibaba.nacos.common.notify.Event;
import com.alibaba.nacos.common.notify.NotifyCenter;
import com.alibaba.nacos.common.notify.listener.Subscriber;
import com.alibaba.nacos.common.utils.StringUtils;
import lombok.RequiredArgsConstructor;
import org.springdoc.core.AbstractSwaggerUiConfigProperties;
import org.springdoc.core.SwaggerUiConfigProperties;
import org.springframework.beans.factory.InitializingBean;
import org.springframework.boot.autoconfigure.condition.ConditionalOnProperty;
import org.springframework.cloud.client.discovery.DiscoveryClient;
import org.springframework.context.annotation.Configuration;
import java.util.Set;
import java.util.stream.Collectors;


@Configuration(proxyBeanMethods = false)
@RequiredArgsConstructor
@ConditionalOnProperty(name = "springdoc.api-docs.enabled", matchIfMissing = true)
public class SpringDocConfiguration implements InitializingBean {

   private final SwaggerUiConfigProperties swaggerUiConfigProperties;

   private final DiscoveryClient discoveryClient;

   /**
    * 在初始化后调用的方法,用于注册SwaggerDocRegister订阅器
    */
   @Override
   public void afterPropertiesSet() {
      SwaggerDocRegister swaggerDocRegister = new SwaggerDocRegister(swaggerUiConfigProperties, discoveryClient);
      // 手动调用一次,避免监听事件掉线问题
      swaggerDocRegister.onEvent(null);
      NotifyCenter.registerSubscriber(swaggerDocRegister);
   }

}

/**
 * Swagger文档注册器,继承自Subscriber<InstancesChangeEvent>
 */
@RequiredArgsConstructor
class SwaggerDocRegister extends Subscriber<InstancesChangeEvent> {

   private final SwaggerUiConfigProperties swaggerUiConfigProperties;

   private final DiscoveryClient discoveryClient;

   /**
    * 事件回调方法,处理InstancesChangeEvent事件
    * @param event 事件对象
    */
   @Override
   public void onEvent(InstancesChangeEvent event) {
      Set<AbstractSwaggerUiConfigProperties.SwaggerUrl> swaggerUrlSet = discoveryClient.getServices()
         .stream()
         .flatMap(serviceId -> discoveryClient.getInstances(serviceId).stream())
         .filter(instance -> StringUtils.isNotBlank(instance.getMetadata().get("spring-doc")))
         .map(instance -> {
            AbstractSwaggerUiConfigProperties.SwaggerUrl swaggerUrl = new AbstractSwaggerUiConfigProperties.SwaggerUrl();
            swaggerUrl.setName(instance.getServiceId());
            swaggerUrl.setUrl(String.format("/%s/v3/api-docs", instance.getMetadata().get("spring-doc")));
            return swaggerUrl;
         })
         .collect(Collectors.toSet());

      swaggerUiConfigProperties.setUrls(swaggerUrlSet);
   }

   /**
    * 订阅类型方法,返回订阅的事件类型
    * @return 订阅的事件类型
    */
   @Override
   public Class<? extends Event> subscribeType() {
      return InstancesChangeEvent.class;
   }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

青春1314

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值