
Spring是分层的javaSE/EE 应用 full-stack(全栈) 轻量级开源框架,以 loC ( Inverse Of control : 反转控制) 和 AOP ( Aspect Oriented Programming : 面向切面编程) 为内核
Spring提供了展现层 SpringMVC 和持久层 Spring JDBCTemplate 以及业务层事务管理等众多的企业级应用技术,还能整合开源世界众多著名的第三方框架和类库,逐渐成为使用最多的 Java EE 企业应用开源框架。
人物:Rod Johnson (Spring之父) 书籍: 《Expert One-on-One J2EE Design and Development 》 · 这是 Rod Johnson 在2002年写的书,该书讲述了 J2EE 使用 EJB 开发设计的优点及解决方案 《 Expert One-on-One J2EE Development without EJB 》 · 两年后 Rod 在2004年写出了这本书,该书讲述了 J2EE 使用 EJB 开发设计的缺点,并对该种模式提出了解决方案 (Spring雏形)
通过Spring提供的IoC容器,可以将对象间的依赖关系交由Spring进行控制,避免硬编码所造成的过渡耦合。
用户也不必再为单例模式类,属性文件解析等这些很底层的需求编写代码,可以更专注于上层应用。
通过Spring的 AOP 功能,方便进行面向切面编程,许多不容易用传统 OOP 实现的功能可以通过 AOP 轻松实现。
可以将我们从单调烦闷的事务管理代码中解脱出来,通过声明方式灵活的进行事务管理,提高开发效率和质量
可以用非容器依赖的编程方式进行几乎所有的测试工作,测试不再是昂贵的操作,而是随手可做的事情
Spring对各种优秀框架 (Struts、 Hibemate、 Hessian、 Quartz 等) 的支持
Spring 的源代码设计精妙、结构清晰、匠心独用,处处体现着大师对 Java 设计模式灵活运用以及对 Java 技术的高深造诣。
它的源代码无疑是 Java 技术的最佳实践范例

类 TestDemo = Spring客户端.getBean(id) 的方式接受对象用于配置对象交由Spring来创建。
默认情况下它调用的是类中的无参构造函数,如果没有无参构造函数则不能创建成功。
基本属性:
无参构造方法实例化
<bean id="唯一标识" class="全限定名"></bean>工厂静态方法实例化
<bean id="唯一标识" class="全限定名-指定工厂的类" factory-mthod="工厂类中的方法"></bean>工厂实例方法实例化
<bean id="唯一标识-工厂" class="全限定名-指定工厂的类"></bean><!--实例方法需要先创建工厂类-->
<bean id="唯一标识" factory="唯一标识-工厂" factory-method="工厂类中的方法"></bean> 依赖注入 ( Dependency Injection) :它是Spring框架核心 IOC 的具体实现
在编写程序时,通过控制反转,把对象的创建交给了Spring,但是代码中不可能出现没有依赖的情况。
IOC 解耦知识降低它们的依赖关系,但不会消除。 例如:业务层仍会调用持久层的方法。
那这种业务层和持久层的依赖关系,在使用 Spring 之后,就让 Spring 来维护了。 简单的说,就是坐等框架把持久层对象传入业务层,而不用我们自己去获取
例: 将DAO注入进Service中,在使用容器时,指向该Service,可以获取到该Service的实例 并可以针对Service进行操作,而Service中,存在DAO,在编写Service时,使用容器,也可以针对DAO进行操作
构造方法
<bean id="指定的另一个bean标识符" class="标识符对象路径"></bean>
<bean id="指定标识符" class="标识符对象路径">
<constructor-arg name="有参构造方法的参数名" ref="指定的另一个bean标识符"></constructor-arg>
</bean>set 方法
<bean id="指定的另一个bean标识符" class="标识符对象路径"></bean>
<bean id="指定标识符" class="标识符对象路径">
<property name="set方法的属性" ref="指定的另一个bean标识符"></property>
</bean>set方法的简单写法:
xmlns:p="http://www.springframework.org/schema/p" <!--需要引入-->
<bean id="指定标识符" class="标识符对象路径" p:userDao-ref="指定的另一个bean标识符"></bean>除了对象的引用可以注入,普通的数据类型,集合等都可以在容器中进行注入
注入数据的三种数据类型:
普通数据类型
<bean id="标识符" class="标识符路径">
<property name="属性名" value="属性值"></property>
</bean>引用数据类型
集合数据类型
<bean id="标识符" class="标识符路径">
<property name="属性名">
<list>
<value>a1</value>
<value>c3</value>
</list>
</property>
</bean>Map:
<bean id="标识符" class="标识符路径">
<property name="属性名">
<map>
<entry key="键1" value-ref="bean标识名1"></entry>
<entry key="键2" value-ref="bean标识名2"></entry>
</map>
</property>
</bean>
<bean id="bean标识名1" class="标识符对象路径">
<property name="属性" value="值"></property>
</bean>
<bean id="bean标识名2" class="标识符对象路径">
<property name="属性" value="值"></property>
</bean>实际开发中,Spring的配置内容非常多,这就导致Spring配置很繁杂且体积大, 所以,可以将部分配置拆解到其他配置文件中,而Spring主配置文件通过 import 标签进行加载
<import resource="配置文件路径"></import>Spring的重点配置:
<Bean><!--标签:Spring的关键-->
<!--id属性:在容器中Bean实例的唯一标识,不允许重复-->
<!--class属性:要实例化的Bean的全限定名-->
<!--scope熟悉的:Bean的作用范围,常用时Singleton(默认)和prototype-->
<property><!--标签:属性注入-->
<!--name属性:属性名称-->
<!--value属性:注入的普通属性值-->
<!--erf属性:注入的对象引用值-->
<list><!--用于list数据类型的数据传递-->
<value></value><!--用于list数据类型里值的设置-->
</list>
<map><!--用于map数据类型的数据传递-->
<entry></entry><!--用于设置map数据类型里的值-->
</map>
</property>
<construcor-arg><!--标签:构造方法注入-->
</construcor-arg>
</Bean>
<import><!--标签:导入其他的Spring的分文件--> 接口类型,代表应用上下文,可以通过其实例获得Spring容器中的Bean对象
/*
* 此方法可以使用多个userService地址,
* 因为它并没有对getBean声明所需类名,只是针对唯一标识符
* */
public Object getBean(String name) throws BeansException {
this.assertBeanFactoryActive();
return this.getBeanFactory().getBean(name);
}
/*
* 当存在多个UserService地址时,此方法将会报错
* 因此,此方法只能确保UserService地址只有一个的情况下使用
* */
public <T> T getBean(String name, Class<T> requiredType) throws BeansException {
this.assertBeanFactoryActive();
return this.getBeanFactory().getBean(name, requiredType);
}ApplicationContext app = new ClassPathXmlApplicationContext("xml文件");
app.getBean("唯一标识符");
app.getBean(class);