开源框架Spring详解---IoC控制反转(一)
spring在英文里有春天、弹簧、跳跃和泉眼的意思。Spring 也表示是一个开源框架,是为了解决企业应用程序开发复杂性由Rod Johnson创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 J2EE 应用程序开发提供集成的框架。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。
Spring是一个开源框架,它由Rod Johnson创建。它是为了解决企业应用开发的复杂性而创建的。Spring使用基本的JavaBean来完成以前只可能由EJB完成的事情。然而,Spring的用途不仅限于服务器端的开发。从简单性、可测试性和松耦合的角度而言,任何Java应用都可以从Spring中受益。
目的:解决企业应用开发的复杂性
功能:使用基本的JavaBean代替EJB,并提供了更多的企业应用功能
范围:任何Java应用
简单来说,Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架。
轻量——从大小与开销两方面而言Spring都是轻量的。完整的Spring框架可以在一个大小只有1MB多的JAR文件里发布。并且Spring所需的处理开销也是微不足道的。此外,Spring是非侵入式的:典型地,Spring应用中的对象不依赖于Spring的特定类。
控制反转——Spring通过一种称作控制反转(IoC)的技术促进了松耦合。当应用了IoC,一个对象依赖的其它对象会通过被动的方式传递进来,而不是这个对象自己创建或者查找依赖对象。你可以认为IoC与JNDI相反——不是对象从容器中查找依赖,而是容器在对象初始化时不等对象请求就主动将依赖传递给它。
面向切面——Spring提供了面向切面编程的丰富支持,允许通过分离应用的业务逻辑与系统级服务(例如审计(auditing)和事务(transaction)管理)进行内聚性的开发。应用对象只实现它们应该做的——完成业务逻辑——仅此而已。它们并不负责(甚至是意识)其它的系统级关注点,例如日志或事务支持。
容器——Spring包含并管理应用对象的配置和生命周期,在这个意义上它是一种容器,你可以配置你的每个bean如何被创建——基于一个可配置原型(prototype),你的bean可以创建一个单独的实例或者每次需要时都生成一个新的实例——以及它们是如何相互关联的。然而,Spring不应该被混同于传统的重量级的EJB容器,它们经常是庞大与笨重的,难以使用。
框架——Spring可以将简单的组件配置、组合成为复杂的应用。在Spring中,应用对象被声明式地组合,典型地是在一个XML文件里。Spring也提供了很多基础功能(事务管理、持久化框架集成等等),将应用逻辑的开发留给了你。
所有Spring的这些特征使你能够编写更干净、更可管理、并且更易于测试的代码。它们也为Spring中的各种模块提供了基础支持。
下面就搭建一个简单的Spring项目:
1、首先要引入Spring的jar包。
Spring有两个jar包:
spring.jar
commons-logging.jar
2、然后写一个xml文件,这个xml文件可以随便起名字,但是Spring的官方网站就是写的是applicationContext.xml.所以我们最好也写成application.xml
Xml代码
<?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-2.0.xsd">
<!-- 配置一个bean 指明bean id class property属性 value属性值 加载这个文件的时候 进行初始化 (需要根据bean的配置)-->
<bean id="greetingServiceImpl" class="cn.csdn.service.GreetingServiceImpl">
<!-- 通过构造器参数的索引位置匹配方法 索引位置从0开始
<constructor-arg index="0">
<value>z_xiaofei168</value>
</constructor-arg>
<constructor-arg index="1">
<value>你好!</value>
</constructor-arg>
-->
<!-- 通过构造器的参数类型匹配方法进行注入 -->
<constructor-arg type="java.lang.String">
<value>你好!</value>
</constructor-arg>
<constructor-arg type="java.lang.String">
<value>z_xiaofei168</value>
</constructor-arg>
<!-- 通过set方法进行注入,必须在你类中有对应的set方法
<property name="say">
<value>你好!</value>
</property>
-->
</bean>
</beans>
3、再次写service层:
GreetingService.java
Java代码
package cn.csdn.service;
public interface GreetingService {
public void say();
}
GreetingServiceImpl.java
Java代码
package cn.csdn.service;
public class GreetingServiceImpl implements GreetingService {
/**私有属性*/
private String say;
/**在定义一个私有的属性*/
private String name;
/**
* IOC依赖注入的方式
* 2、通过构造器注入
* */
public GreetingServiceImpl(String name,String say){
this.name=name;
this.say=say;
}
@Override
public void say() {
System.out.println("你给"+name+"打的招呼是:"+say);
}
/**
* IOC依赖注入的方式
* 1、通过setter方法实现的
* */
/**set方法进行初始化的工作*/
public void setSay(String say){
this.say=say;
}
}
4、最后写个测试类来测试:
Java代码
package cn.csdn.junit;
import org.junit.Test;
import org.springframework.context.ApplicationContext;
import org.springframework.context.support.ClassPathXmlApplicationContext;
import org.springframework.context.support.FileSystemXmlApplicationContext;
import cn.csdn.service.GreetingService;
public class GreetingTest {
/**测试GreetingServiceImpl的方法*/
@Test
public void test1(){
/**加载spring容器 可以解析多个配置文件 采用数组的方式传递*/
ApplicationContext ac = new ClassPathXmlApplicationContext(new String[]{"applicationContext.xml"});
/**IOC的控制反转体现*/
GreetingService greetingService = (GreetingService) ac.getBean("greetingServiceImpl");
greetingService.say();
}
@Test
public void test2(){
ApplicationContext ac = new FileSystemXmlApplicationContext(new String[]{"src/applicationContext.xml"});
/**IOC的控制反转体现*/
GreetingService greetingService = (GreetingService) ac.getBean("greetingServiceImpl");
greetingService.say();
}
}
5、在控制台的显示结果是:
你给z_xiaofei168打的招呼是:你好!