Spring 源码中一些小工具

1.  包扫描方法,扫描指定包路径下的类  

 org.springframework.context.annotation.ClassPathBeanDefinitionScanner#doScan

 在指定的基本包内执行扫描,返回注册的bean定义。

 核心扫描逻辑代码 

 org.springframework.context.annotation.ClassPathScanningCandidateComponentProvider#scanCandidateComponents

 可以把这部分源码进行魔改 ,改写成一个工具类 扫描指定路径下的类,参考 componentScan注解的配置方法。

 样例代码:

public class ClassScaner implements ResourceLoaderAware {

    //保存过滤规则要排除的注解
    private final List<TypeFilter> includeFilters = new LinkedList<TypeFilter>();
    private final List<TypeFilter> excludeFilters = new LinkedList<TypeFilter>();

    private ResourcePatternResolver resourcePatternResolver = new PathMatchingResourcePatternResolver();
    private MetadataReaderFactory metadataReaderFactory = new CachingMetadataReaderFactory(this.resourcePatternResolver);

    public static Set<Class> scan(String[] basePackages,
                                  Class<? extends Annotation>... annotations) {
        ClassScaner cs = new ClassScaner();

        if (ArrayUtils.isNotEmpty(annotations)) {
            for (Class anno : annotations) {
                cs.addIncludeFilter(new AnnotationTypeFilter(anno));
            }
        }

        Set<Class> classes = new HashSet<Class>();
        for (String s : basePackages)
            classes.addAll(cs.doScan(s));
        return classes;
    }

    public static Set<Class> scan(String basePackages, Class<? extends Annotation>... annotations) {
        return ClassScaner.scan(StringUtils.tokenizeToStringArray(basePackages, ",; \t\n"), annotations);
    }

    public final ResourceLoader getResourceLoader() {
        return this.resourcePatternResolver;
    }

    public void setResourceLoader(ResourceLoader resourceLoader) {
        this.resourcePatternResolver = ResourcePatternUtils
                .getResourcePatternResolver(resourceLoader);
        this.metadataReaderFactory = new CachingMetadataReaderFactory(
                resourceLoader);
    }

    public void addIncludeFilter(TypeFilter includeFilter) {
        this.includeFilters.add(includeFilter);
    }

    public void addExcludeFilter(TypeFilter excludeFilter) {
        this.excludeFilters.add(0, excludeFilter);
    }

    public void resetFilters(boolean useDefaultFilters) {
        this.includeFilters.clear();
        this.excludeFilters.clear();
    }

    public Set<Class> doScan(String basePackage) {
        Set<Class> classes = new HashSet<Class>();
        try {
            String packageSearchPath = ResourcePatternResolver.CLASSPATH_ALL_URL_PREFIX
                    + org.springframework.util.ClassUtils
                    .convertClassNameToResourcePath(SystemPropertyUtils
                            .resolvePlaceholders(basePackage))
                    + "/**/*.class";
            Resource[] resources = this.resourcePatternResolver
                    .getResources(packageSearchPath);

            for (int i = 0; i < resources.length; i++) {
                Resource resource = resources[i];
                if (resource.isReadable()) {
                    MetadataReader metadataReader = this.metadataReaderFactory.getMetadataReader(resource);
                    if ((includeFilters.size() == 0 && excludeFilters.size() == 0)
                            || matches(metadataReader)) {
                        try {
                            classes.add(Class.forName(metadataReader
                                    .getClassMetadata().getClassName()));
                        } catch (ClassNotFoundException e) {
                            e.printStackTrace();
                        }
                    }
                }
            }
        } catch (IOException ex) {
            throw new BeanDefinitionStoreException(
                    "I/O failure during classpath scanning", ex);
        }
        return classes;
    }

    protected boolean matches(MetadataReader metadataReader) throws IOException {
        for (TypeFilter tf : this.excludeFilters) {
            if (tf.match(metadataReader, this.metadataReaderFactory)) {
                return false;
            }
        }
        for (TypeFilter tf : this.includeFilters) {
            if (tf.match(metadataReader, this.metadataReaderFactory)) {
                return true;
            } else {
                return false;
            }
        }
        return true;
    }

    public static void main(String[] args) {
        ClassScaner.scan("com.onion.service", Service.class)
                .forEach(clazz -> System.out.println(clazz));
    }
}

2.获取当前默认的类加载器

  使用 ClassUtils.getDefaultClassLoader()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一个基于Spring Boot的开发框架,用于构建分布式系统的微服务架构。Spring Cloud小程序项目源码是指使用Spring Cloud框架开发的一个小程序项目的代码。 Spring Cloud小程序项目源码通常包括以下几个部分: 1. 服务注册与发现:使用Eureka或Consul等服务注册心组件,实现服务的自动注册与发现。 2. 基础服务模块:通常包括用户认证与授权、日志管理、配置心等基础功能模块,提供可复用的服务。 3. 微服务模块:根据业务需求划分为不同的微服务模块,例如用户管理、商品管理、订单管理等。 4. API网关:使用Zuul或Spring Cloud Gateway等组件,对外提供统一的API入口,并进行路由、鉴权等处理。 5. 配置心:使用Spring Cloud Config等组件,集管理微服务的配置信息,实现动态配置更新。 6. 断路器与容错管理:使用Hystrix等断路器组件,实现服务的容错保护与熔断处理。 7. 分布式追踪与监控:使用Zipkin等分布式追踪组件,实现对服务调用链的追踪与监控。 8. 消息队列:使用Kafka或RabbitMQ等消息队列组件,实现微服务间的异步通信与解耦。 通过使用Spring Cloud框架开发小程序项目,可以实现微服务的快速开发与部署,提高系统的可扩展性与灵活性。同时,Spring Cloud还提供了丰富的插件与工具,简化了微服务架构的开发与管理,降低了开发成本。 总之,Spring Cloud小程序项目源码是一个基于Spring Cloud框架开发的小程序项目的代码,通过使用该源码可以了解与学习Spring Cloud微服务架构的设计与实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值