Spring---将Spring工程中的 xml 配置方式改为 全注解方式 (@Configuration)

54 篇文章 1 订阅
举例若对于以下 xml 配置:
    <bean id="jcqConsumer" class="com.jcloud.jcq.spring.demo.consumer.JCQConsumer" init-method="start" destroy-method="shutdown">
        <!-- 消费者 -->
        <property name="consumer" ref="consumer" />
        <!-- 订阅的topic和对应的消息监听器的map -->
        <property name="topicMessageListenerMap">
            <map>
                <entry key="test-message-proxy">
                    <bean class="com.jcloud.jcq.spring.demo.consumer.DefaultMessageListener" />
                </entry>
            </map>
        </property>
        <!-- 订阅的topic和对应的过滤条件的map -->
        <property name="topicFilterExpressionMap">
            <map>
                <!-- 过滤条件为null -->
                <entry key="test-message-proxy">
                    <null/>
                </entry>
            </map>
        </property>
    </bean>
修改为的配置注解类为:
    @Bean(initMethod = "start", destroyMethod = "shutdown")
    public JCQConsumer jcqConsumer(Consumer consumer, DefaultMessageListener defaultMessageListener) {
        JCQConsumer jcqConsumer = new JCQConsumer();
        // 消费者
        jcqConsumer.setConsumer(consumer);
        // 订阅的topic和对应的消息监听器的map
        Map<String, MessageListener> topicMessageListenerMap = new HashMap<>();
        topicMessageListenerMap.put("test-message-proxy", defaultMessageListener);
        jcqConsumer.setTopicMessageListenerMap(topicMessageListenerMap);
        // 订阅的topic和对应的过滤条件的map
        Map<String, FilterExpression> topicFilterExpressionMap = new HashMap<>();
        topicFilterExpressionMap.put("test-message-proxy", null);
        jcqConsumer.setTopicFilterExpressionMap(topicFilterExpressionMap);
        System.out.println(topicFilterExpressionMap.get("test-message-proxy"));

        return jcqConsumer;
    }
说明
  1. JCQConsumer为项目中自定义的类,其中定义了 start() 与 shutdown() 方法,在 配置类中使用注解@Bean(initMethod = "start", destroyMethod = "shutdown")标注
  2. bean的id 为方法名,class 为方法的返回值类型
  3. property 属性中若有 ref 项,应该添加到该 方法的入口参数中 ,如上的 <property name="consumer" ref="consumer" /> 在配置类方法中应该添加参数Consumer consumer,这里注意 consumer 之前应该已经通过 @Bean 已添加到容器中

参考:https://blog.csdn.net/dawn2134/article/details/90940175

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot 配置处理器(spring-boot-configuration-processor)是 Spring Boot 应用程序使用的一个注释处理器,它可以帮助我们自动生成配置文件的帮助信息和代码提示。 下面是使用 Spring Boot 配置处理器的快速入门指南。 1. 添加依赖 在 `pom.xml` 文件添加以下依赖: ```xml <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-configuration-processor</artifactId> <optional>true</optional> </dependency> ``` 2. 添加注解 在需要生成配置文件帮助信息和代码提示的配置类上添加以下注解: ```java import org.springframework.boot.context.properties.ConfigurationProperties; import org.springframework.stereotype.Component; @Component @ConfigurationProperties(prefix = "myapp") public class MyAppProperties { // ... } ``` 这里的 `@ConfigurationProperties` 注解用于指定配置类的属性前缀,这样在配置文件使用该前缀就可以自动完成属性的注入。 3. 生成帮助信息 在项目编译时,Spring Boot 配置处理器会自动扫描 `@ConfigurationProperties` 注解,并生成一个 `META-INF/spring-configuration-metadata.json` 文件。该文件包含了配置属性的帮助信息和默认值,可以被 IDE 用于代码提示和自动完成。 4. 使用代码提示 完成以上步骤后,在配置文件输入前缀后,IDE 会自动提示可用的配置属性和默认值。 如,在 `application.properties` 文件输入 `myapp.` 后,IDE 会提示可用的属性和默认值。 ```properties myapp.name=MyApp myapp.version=1.0.0 myapp.debug=false ``` 以上就是使用 Spring Boot 配置处理器的快速入门指南。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值