spring--IOC

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>




  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值