自制Spring-boot Starter

  1. 新建Spring boot项目

    <parent>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-parent</artifactId>
      <version>2.7.0</version>
      <relativePath/> <!-- lookup parent from repository -->
    </parent>
    <groupId>com.example</groupId>
    <artifactId>web-filter-log-boot-starter</artifactId>
    <dependency>
      <groupId>org.springframework.boot</groupId>
      <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    
  2. 定义一个web过滤器,验证Spring boot starter是否生效

    // Filter
    public class LogFilter implements Filter {
    
        private Logger logger = LoggerFactory.getLogger(LogFilter.class);
    
        @Override
        public void init(FilterConfig filterConfig) throws ServletException {
            System.err.println("logFilter init...");
            logger.info("logFilter init...");
        }
    
        @Override
        public void doFilter(ServletRequest servletRequest, ServletResponse servletResponse, FilterChain filterChain) throws IOException, ServletException {
            HttpServletRequest httpServletRequest = (HttpServletRequest) servletRequest;
            logger.info("uri: {} is working.", httpServletRequest.getRequestURI());
            filterChain.doFilter(servletRequest,servletResponse);
        }
    
        @Override
        public void destroy() {
            logger.info("logFilter destroy...");
        }
    }
    
    // 配置Filter生效
    public class LogFilterRegistrationBean extends FilterRegistrationBean<LogFilter> {
        public LogFilterRegistrationBean() {
            super();
            this.setFilter(new LogFilter());
            this.addUrlPatterns("/*");
            this.setName("LogFilter");
            this.setOrder(1);
        }
    }
    

    定义自动配置类

    // 自动配置类
    @Configuration
    @ConditionalOnClass({LogFilterRegistrationBean.class, LogFilter.class})
    public class LogFilterAutoConfiguration {
        @Bean
        @ConditionalOnMissingBean(LogFilterRegistrationBean.class)
        public LogFilterRegistrationBean logFilterRegistrationBean() {
            return new LogFilterRegistrationBean();
        }
    }
    
  3. 定义注解,使用注解将使该starter配置生效

    @Target(ElementType.TYPE)
    @Retention(RetentionPolicy.RUNTIME)
    @Import(EnableLogFilterImportSelector.class)
    public @interface EnableLogFilter {
    
    }
    
  4. 定义EnableLogFilterImportSelector用于从spring.factories加载starter自动配置类

    public class EnableLogFilterImportSelector implements DeferredImportSelector, BeanClassLoaderAware, EnvironmentAware {
    
        private ClassLoader beanClassLoader;
        private Class annotationClass = EnableLogFilter.class;
    
        @Override
        public String[] selectImports(AnnotationMetadata importingClassMetadata) {
    
            var attributes =
                    AnnotationAttributes.fromMap(importingClassMetadata
                            .getAnnotationAttributes(annotationClass.getName(), true));
            List<String> factories = new ArrayList<>(
                    new LinkedHashSet<>(SpringFactoriesLoader.loadFactoryNames(this.annotationClass, this.beanClassLoader)));
            return factories.toArray(new String[factories.size()]);
        }
    
        @Override
        public void setEnvironment(Environment environment) {
    
        }
    
        @Override
        public void setBeanClassLoader(ClassLoader classLoader) {
            this.beanClassLoader = classLoader;
        }
    }
    
  5. 在resources/META-INF中添加spring.factories

    com.example.annotation.EnableLogFilter=com.example.config.LogFilterAutoConfiguration
    
  6. 使用starter

    <dependency>
      <groupId>com.example</groupId>
      <artifactId>web-filter-log-boot-starter</artifactId>
    </dependency>
    

    在启动类上添加EnableLogFilter注解,使starter自动配置生效

    @SpringBootApplication
    @EnableLogFilter
    public class DemoBootApplication {
    
        public static void main(String[] args) {
            SpringApplication.run(DemoBootApplication.class, args);
        }
    
    }
    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
spring-boot-starter-jpa和spring-boot-starter-jdbc是Spring Boot框架中用于数据库访问的两个常用依赖库,它们在数据库访问方式和功能上有一些区别。 spring-boot-starter-jpa是基于Java Persistence API(JPA)的依赖库,它提供了一种面向对象的方式来进行数据库访问。JPA是Java EE的一部分,它定义了一套标准的API和规范,用于实现对象关系映射(ORM)。使用spring-boot-starter-jpa可以方便地进行实体类与数据库表之间的映射,通过简单的注解和配置,可以实现数据库的增删改查操作。同时,spring-boot-starter-jpa还提供了一些高级特性,如事务管理、缓存等。 相比之下,spring-boot-starter-jdbc是基于Java Database Connectivity(JDBC)的依赖库。JDBC是Java语言访问关系型数据库的标准API,它提供了一套用于执行SQL语句和处理结果集的方法。使用spring-boot-starter-jdbc可以直接使用JDBC API进行数据库操作,需要手动编写SQL语句和处理结果集。相对于JPA,JDBC更加底层,更加灵活,可以直接操作数据库的细节。 总结一下区别: 1. 数据库访问方式:spring-boot-starter-jpa使用面向对象的方式进行数据库访问,而spring-boot-starter-jdbc使用基于SQL的方式进行数据库访问。 2. 抽象程度:spring-boot-starter-jpa提供了更高级的抽象,通过注解和配置可以实现对象关系映射,而spring-boot-starter-jdbc需要手动编写SQL语句和处理结果集。 3. 功能特性:spring-boot-starter-jpa提供了一些高级特性,如事务管理、缓存等,而spring-boot-starter-jdbc相对较为简单,功能相对较少。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值