zoukankan      html  css  js  c++  java
  • Spring Ioc 基于Java的容器配置

    一、基于Java的容器配置

    @Configuration & @Bean 注解:

             在Spring的新的Java-Configuration的中间产物是基于类的@Configuration的注解和基于方法的@Bean注解。
             @Bean注解是用来指明方法的实例化,配置和初始化一个对象是通过Spring的IoC容器来管理的。对于那些熟悉使用以XML配置Spring的<beans /> 标签,@Bean注解和<bean />标签是起相同作用的。你能和Spring的@Component注解的组件一起使用@Bean注解方法, 然而,这些@Bean注解的方法通常是和@Configuration的Bean。
            @Configuration注解的类指明该类主要是作为一个bean的来源定义。此外,@Configurationd定义的classes允许在同一个类中使用@Bean定义的方法来定义依赖的bean 
    注释类与@Configuration表示这个类可以使用Spring IoC容器为bean定义的来源。在@Bean 注解告诉Spring的注解为@Bean的一个方法将返回应注册为在Spring应用程序上下文中的bean对象。最简单可行的@Configuration类将如下所示: 

    上面的AppConfig类等效于以下Spring <beans/>XML:

    JavaConfig是Spring的一个子项目, 它皆在通过Java类的方式提供 Bean的定义信息.  普通的POJO只要标注了 @Configuration注解, 就可以为 Spring 容器提供Bean定义的信息了. 每个标注了 @Bean注解的方法都相当于提供了 Bean的定义信息.
    使用 @Configuration 注解标注配置类:

    基于Java类定义Bean配置元数据,其实就是通过Java类定义Spring配置元数据,且直接消除XML配置文件。
    首先让我们看一下基于Java类如何定义Bean配置元数据,具体步骤如下:
    1. 使用@Configuration注解需要作为配置的类,表示该类将定义Bean的元数据
    2. 使用@Bean注解相应的方法,该方法名默认就是Bean的名称,该方法返回值就是Bean的对象。
    3. AnnotationConfigApplicationContext或子类进行加载基于java类的配置

    1、(Manager实体这里就不截图了)

     

    上面的代码将等同于下面的XML配置:

    <bean id="mgr" class="org.sl.netmarket.entities.Manager"/>

    注解为@Bean的方法名称作为工作bean的id,它创建并返回实际的bean。配置类可以有声明多个@Bean。一旦配置类定义,可以加载和提供他们使用AnnotationConfigApplicationContext 

    Spring 提供了一个 AnnotationConfigApplicationContext 类. 它能够直接通过标注 @Configuration  的Java类启动容器. 如下,以Spring容器:

    2.

    AnnotationConfigApplicationContext 支持加载多个 @Configuration 的Java类. 然后通过刷新容器应用配置这些类. 

    也可以通过 @Import 注解,  将多个配置类组装到一个配置类中, 只需要加载一个配置类就可以.

    结果:

    这么做有什么好处呢?

         1.使用纯java代码,不在需要xml

         2.在配置中也可享受OO带来的好处

         3.类型安全对重构也能提供良好的支持

         4.依旧能享受到所有springIoC容器提供的功能


            ApplicationContext 接口的最常用的实现类是 ClassPathXmlApplicationContext 和 FileSystemXmlApplicationContext,以及面向 Portlet 的 XmlPortletApplicationContext 和面向 web 的 XmlWebApplicationContext,它们都是面向 XML 的。Spring 3.0 新增了另外两个实现类:AnnotationConfigApplicationContext 和 AnnotationConfigWebApplicationContext。从名字便可以看出,它们是为注解而生,直接依赖于注解作为容器配置信息来 源的 IoC 容器初始化类。由于 AnnotationConfigWebApplicationContext 是 AnnotationConfigApplicationContext 的 web 版本,其用法与后者相比几乎没有什么差别,因此本文将以 AnnotationConfigApplicationContext 为例进行讲解。
            AnnotationConfigApplicationContext 搭配上 @Configuration 和 @Bean 注解,自此,XML 配置方式不再是 Spring IoC 容器的唯一配置方式。两者在一定范围内存在着竞争的关系,但是它们在大多数情况下还是相互协作的关系,两者的结合使得 Spring IoC 容器的配置更简单,更强大。之前,我们将配置信息集中写在 XML 中,如今使用注解,配置信息的载体由 XML 文件转移到了 Java 类中。我们通常将用于存放配置信息的类的类名以 “Config” 结尾,比如 AppDaoConfig.java、AppServiceConfig.java 等等。我们需要在用于指定配置信息的类上加上 @Configuration 注解,以明确指出该类是 Bean 配置的信息源。

    注意:Spring 对标注 Configuration 的类有如下要求
    配置类不能是 final 的;配置类不能是本地化的,亦即不能将配置类定义在其他类的方法内部;配置类必须有一个无参构造函数。AnnotationConfigApplicationContext 将配置类中标注了 @Bean 的方法的返回值识别为 Spring Bean,并注册到容器中,受 IoC 容器管理。@Bean 的作用等价于 XML 配置中的 标签。

    @Bean 具有以下四个属性: 
    name -- 指定一个或者多个 Bean 的名字。这等价于 XML 配置中 的 name 属性。

    initMethod -- 容器在初始化完 Bean 之后,会调用该属性指定的方法。这等价于 XML 配置中 的 init-method 属性。

    destroyMethod -- 该属性与 initMethod 功能相似,在容器销毁 Bean 之前,会调用该属性指定的方法。这等价于 XML 配置中 的 destroy-method 属性。

    autowire -- 指定 Bean 属性的自动装配策略,取值是 Autowire 类型的三个静态属性。Autowire.BY_NAME,Autowire.BY_TYPE,Autowire.NO。与 XML 配置中的 autowire 属性的取值相比,这里少了 constructor,这是因为 constructor 在这里已经没有意义了。@Bean 没有直接提供指定作用域的属性,可以通过 @Scope 来实现该功能。

    由于@configureation注解类本身已经标注了@component注解,所以任何标注了@configuration的类,本身也相当于标注了@component,即它们可以像普通的bean一样被注入到其它bean中去。

    二、基于配置文件及Java类

    1、先创建一个实体类

    @component (把普通pojo实例化到spring容器中,相当于配置文件中的 
    <bean id="" class=""/>)

    泛指各种组件,就是说当我们的类不属于各种归类的时候(不属于@Controller、@Services等的时候),我们就可以使用@Component来标注这个类。

    https://www.cnblogs.com/xss512/p/10905006.html

    2、配置xml文件

    扫描需要的包,是扫描注解了@Component的实体类

    3、

    结果:

    这就获得了manager的实例了

  • 相关阅读:
    [非技术]简单预测中美关系未来的走向
    权限系统模型和常用权限框架
    [Tomcat]了解Tomcat,从它的结构开始
    [Mybatis]用AOP和mybatis来实现一下mysql读写分离
    [MQ]说一说MQ消息积压
    [MQ]再谈延时队列
    [Web] 浅谈Cookie,Session,Token
    k8s搭建
    微信公众平台开发(2)扫描二维码添加公众账号
    微信公众平台开发模式
  • 原文地址:https://www.cnblogs.com/xss512/p/10899380.html
Copyright © 2011-2022 走看看