代码改变世界

spring mvc 学习指南一

2017-03-02 23:07  backyyan  阅读(327)  评论(0编辑  收藏  举报
Spring框架

 

依赖注入技术,作为代码可测试性的一个解决方案已经被广泛应用,很多人在使用中并不区分依赖注入和控制反转(IOC)

简单来说,依赖注入的情况如下,有两个组件A和B,A依赖与B。假定A是一个类,且A有一个方法importantMethod使用到B,如下

[java] view plain copy print?
public class A {  
    public  void importantMethod(){  
        B b = ...//get an instance of B  
        b.usefulMethod();  
    }  
}        

要使用B,类A 必须先获得组件B的实例引用。若B是一个具体类,则可以通过new关键字直接创建组件B实例。但是,如果B是接口,且有多个实现,则问题就变的复杂,固然可以任意选择接口B的一个实现类,但这也意味着A的可重用性大大降低了,因为无法采用B的其他实现。

 

依赖注入是这样处理此类情景的:接管对象的创建工作,并将该对象的引用注入需要该对象的组件。以上述例子为例,依赖注入框架会分别创建对象A和对象B,将对象B注入到对象A中。

为了能让框架进行依赖注入,需要编写特定的set方法或者构建方法,例如,为了能将B类注入到A类中,类A会被修改成如下形式:

 

[java] view plain copy
 
 print?
public class A {  
    private B b;  
  
    public void importantMethod() {  
        // no nedd to worry about creating b anymore  
        // B b = ...//get an instance of B  
        b.usefulMethod();  
    }  
    public void setB(B b) {  
        this.b = b;  
    }  
}  

修改后的类A新增了一个set方法,该方法将会被框架调用,以注入一个的实例,由于对象依赖由依赖注入,类A的importantMethod方法不再需要在调用B的usefulMethod方法去创建前去创建一个B的实例。

当然,也可以采用构造器的方式注入,如下所示:

[java] view plain copy print?
public class A {  
    private B b;  
    public A (B b){  
        this.b=b;  
    }  
    public void importantMethod() {  
        // no nedd to worry about creating b anymore  
        // B b = ...//get an instance of B  
        b.usefulMethod();  
    }  
}  

本例中,Spring会先创建B的实例,在创建实例A,然后把B注入到实例A中。

 

通过提供一个控制反转容器(或者依赖注入容器),spring为我们提供一种可以聪明的管理Java对象依赖关系的方法。其优雅之处在于,我们了解Spring框架的存在,更不需要引入任何Spring类型。

 

从1.0版本开始,Spring就同时支持setter和构造器方式的依赖注入,从2.5版本开始,通过Autowired注解,Spring支持基于field方式和依赖注入,但缺点是程序必须引入org.springframework.beans.factory.annotation.Autowired,这对Spring产生了依赖,这样,程序无法直接迁移到另一个依赖注入容器间。

使用Spring,程序几乎将所有的重要对象的创建工作移交给Spring,并配置如何注入依赖。Spring支持XML或注解两种配置方式。此外,还需要创建一个ApplicationContext对象,代表一个Spring控制反转容器,org.springframework.context.ApplicationContext接口有多个实现,包裹ClassPathXmlApplicationContext和FileSystemXmlApplicationContext。这两个实现都需要至少一个包含beans信息的XML文件。ClassPathXmlApplictionContext尝试在类加载路径中加载配置文件,而FileSystemXmlApplicationContext则从文件系统中加载。下面从类路径中加载config1.xml和config2.xml的ApplicationContext创建一个代码示例。

[java] view plain copy print?
context = new ClassPathXmlApplicationContext(new String[]{"config1.xml","config2.xml"});  
    //可以通过调用ApplicationContext的getBean方法获得对象。  
    context.getBean("a",A.class);  
    //getBean方法会查询id为a且类型那个为A的bean对象,  

1.1 XML配置文件

从1.0版本开始,spring就支持基于xml的配置,从2.5版本开始,增加了通过注解的配置支持,配置文件的根元素通常为

[html] view plain copy print?
<span style="font-size:14px;"><?xml version="1.0" encoding="UTF-8"?>  
<beans xmlns="http://www.springframework.org/schema/beans"  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  
    xsi:schemaLocation="http://www.springframework.org/schema/beans  
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">  
  
    。。。。。  
  
</beans></span>  

如果需要跟江的Spring配置能力,可以在schema location 属性中添加相应的schema。配置文件可以是一份,也可以分解为多份,已支持模块化配置,ApplictionContext的实现类支持读取多份配置文件。另一种选择是,通过一份主配置文件,将该文件导入到其他的配置文件。下面是一个导入配置文件的示例。

[html] view plain copy print?
<span style="font-size:14px;"><?xml version="1.0" encoding="UTF-8"?>  
<beans xmlns="http://www.springframework.org/schema/beans"  
    xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"  
  
    xsi:schemaLocation="http://www.springframework.org/schema/beans  
http://www.springframework.org/schema/beans/spring-beans-3.2.xsd">  
  
    <import resource="config.xml" />  
    <import resource="module2/congif.xml" />  
    <import resource="/resources/config3.xml" />  
  
</beans></span>