Spring的核心是控制反转(IOC: inversion of control)和面向切面(AOP: aspect oriented program)
1. IOC定义: Inversion of control(控制反转), 从字面上来理解: 当一个对象创建时, 它所依赖的对象由外部传递给他, 而非自己去创建所依赖的对象(比如通过new操作). 因此,也可以说在对象如何获取他所依赖的对象这件事情上, 控制权反转了.
Spring优点:
1. 简化开发,提高效率
由IOC容器来控制对象,使用时只需要去容器中取出该对象,减少了重复创建对象的性能损耗
2.AOP编程的支持:
只需要通过配置就可以完成对事务的管理,避免了重复性的开启和关闭事务
4. 方便集成各种优秀框架
5.降低JavaEE API的使用难度
Spring 对JavaEE开发中非常难用的一些API(JDBC、JavaMail、远程调用等),都提供了封装,使这些API应用难度大大降低.
core
core部分包含4个模块
spring-core:依赖注入IoC与DI的最基本实现
spring-beans:Bean工厂与bean的装配
spring-context:spring的context上下文即IoC容器
spring-expression:spring表达式语言
它们的完整依赖关系
因为spring-core依赖了commons-logging,而其他模块都依赖了spring-core,所以整个spring框架都依赖了commons-logging,如果有自己的日志实现如log4j,可以排除对commons-logging的依赖,没有日志实现而排除了commons-logging依赖,编译报错
AOP
aop部分包含4个模块
spring-aop:面向切面编程
spring-aspects:集成AspectJ
spring-instrument:提供一些类级的工具支持和ClassLoader级的实现,用于服务器
spring-instrument-tomcat:针对tomcat的instrument实现(包含了spring的tomcat设备代理)
它们的完整依赖关系
data access
data access部分包含5个模块
spring-jdbc:jdbc的支持
spring-tx:事务控制
spring-orm:对象关系映射,集成orm框架
spring-oxm:对象xml映射
spring-jms:java消息服务
它们的完整依赖关系
常用的数据连接池:
<!-- 引入外部的数据库配置文件 -->
<context:property-placeholder location="classpath:db.properties"/>
<property name="driverClass" value="${jdbc.driverClass}"></property>用el表达式获取文件中的数据
<!--spring自身的连接池 -->
<!-- <bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/dog"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</bean> -->
<!--dbcp连接池 -->
<!-- <bean id="dataSource" class="org.apache.commons.dbcp.BasicDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/dog"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</bean> -->
<!--Druid连接池 -->
<!-- <bean id="dataSource" class="com.alibaba.druid.pool.DruidDataSource">
<property name="driverClassName" value="com.mysql.jdbc.Driver"></property>
<property name="url" value="jdbc:mysql://localhost:3306/dog"></property>
<property name="username" value="root"></property>
<property name="password" value="123456"></property>
</bean> -->
<!--c3p0连接池 -->
<bean id="dataSource" class="com.mchange.v2.c3p0.ComboPooledDataSource">
<property name="driverClass" value="com.mysql.jdbc.Driver"></property>
<property name="jdbcUrl" value="jdbc:mysql://localhost:3306/dog"></property>
<property name="user" value="root"></property>
<property name="password" value="123456"></property>
</bean>
Set注入与构造注入
<bean id="user012" class="com.lanou.entity.User">
<property name="username" value="lna"></property>
<property name="car" ref="car"></property>
</bean>
<bean id="stu1" class="com.lanou.entity.Student">
<!-- 构造注入
两参构造 double,int可以通过type切换选择对应属性 -->
<constructor-arg index="1" type="int" value="123"></constructor-arg>
<constructor-arg index="0" value="lna"></constructor-arg>
</bean>
扫描注解:
<context:component-scan base-package="com.lanou" use-default-filters="true">
<!-- 扫描基包中的注解 use-default-filters="false"设置之后,可以扫描指定的包 -->
<!-- 排除所有的Service注解 -->
<!-- <context:exclude-filter type="annotation" expression="org.springframework.stereotype.Service"/> -->
<!--排除单个类的注解 com.lanou.entity.UserDao -->
<!-- <context:exclude-filter type="assignable" expression="com.lanou.entity.UserDao"/> -->
<!-- 指定扫描的注解 -->
<!-- <context:include-filter type="annotation" expression=""/ >
<context:include-filter type="assignable" expression=""/> -->
</context:component-scan>