开源框架-Spring系列Spring

[Spring]Spring的Aware接口-装配

2021-01-10  本文已影响0人  AbstractCulture

Aware

Aware:察觉的、意识到的。
英文示例: She was not aware of having done wrong. 她沒有意識到做錯了事。
Spring提供了一系列扩展自顶层接口Aware的接口。开发者实现了该类接口后,可以在接口提供的方法中访问Spring的资源。简单的说,就是实现了该接口,就等于拿到了容器的钥匙。
Spring框架会察觉实现了这类接口的Bean,然后将容器资源传递到方法参数中提供给开发者进行扩展,所以实现了该接口的同时,需要做好信息同步,否则其他开发者会感到诧异-为什么我的Bean发生了别的行为?。

public interface Aware {

}

UML

UML

此处列举的只是常见的Aware接口,还有很多Aware接口,例如:BookstrapContextAwareLoadTimeWeaverAwareNotificationPublishAwarePortletConfigAwareServletConfigAware等等。读者可以自行进行扩展阅读.

Aware

Code示例

由于接口过多,此处仅演示BeanNameAwareApplicationContextAware

通过实现ApplicationContextAware编写一个简易的SpringContextUtil

在开发的过程中,往往需要将一些常用的操作写成工具类,比如Redis、RabbitMQ、Http等。
如果需要用到Spring的Bean,诸如:RedisTemplate、RabbitMQTemplate、RestTemplate。除了使用构造注入将变量赋值给static变量的方式外,还可以通过Aware接口进行getBean()的方式得到这些Bean.

使用的时候是不需要注入SpringContextUtil的,但是需要加上@Component让Spring感知到你的诉求.

package com.xjm.bean.aware;

import org.springframework.beans.BeansException;
import org.springframework.context.ApplicationContext;
import org.springframework.context.ApplicationContextAware;
import org.springframework.stereotype.Component;

/**
 * @author jaymin
 * 2021/1/10 16:22
 */
@Component
public class SpringContextUtil implements ApplicationContextAware {

    private static ApplicationContext applicationContext;

    @Override
    public void setApplicationContext(ApplicationContext applicationContext) throws BeansException {
        SpringContextUtil.applicationContext = applicationContext;
    }

    public static  <T> T getBean(String name, Class<T> requiredType) throws BeansException {
        return applicationContext.getBean(name, requiredType);
    }


}
package com.xjm.bean.aware;

import com.AnnotationContextDemo;
import com.xjm.model.Person;
import org.springframework.context.ApplicationContext;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;

/**
 * @author jaymin
 * 2021/1/10 16:45
 */
public class AwareDemo {
    public static void main(String[] args) {
        // 模拟容器启动,这里不直接使用该applicationContext,仅做组件扫描使用
        ApplicationContext applicationContext = new AnnotationConfigApplicationContext(AnnotationContextDemo.class);
        Person person = SpringContextUtil.getBean("person", Person.class);
        System.out.println("通过Aware接口获取 person 对象:" + person.toString());
    }
}
result

我们通过实现ApplicationContextAware接口,访问到了整个容器上下文,并用简单的委派将getBean变成了静态方法调用。

实现BeanNameAware访问BeanName

package com.xjm.model;

import org.springframework.beans.factory.BeanNameAware;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Component;
import org.springframework.stereotype.Repository;

/**
 * @author jaymin
 * 2020/11/28 0:02
 */
@Repository
public class Person implements BeanNameAware {

    private String name;

    private Integer age;

    public Person(String name) {
        this.name = name;
    }

    public Person() {
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    @Override
    public String toString() {
        return "Person{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

    @Override
    public void setBeanName(String name) {
        System.out.println("Person Instance's Name is " + name);
    }
}
result

总结

上一篇 下一篇

猜你喜欢

热点阅读