spring (一)

spring框架

用途
  1) 整合其他框架,让他们协同工作
  2) 提供了声明式的事务管理 -- 通过配置(xml, 注解)来管理事务
  
两大核心思想:IOC,AOP

 


1. IOC (控制反转)

Inversion of controll :把对象的创建以及某些方法的调用交由容器来管理
spring容器,类似于tomcat容器,但它能容纳的对象类型更为丰富:dao,service,controller
例如有个UserDao类
以前 : UserDao dao =new UserDao();
spring创建 : UserDao dao;


 

2. 使用步骤

1) 创建*.xml

例:UserDao.xml

<?xml version="1.0" encoding="UTF-8" ?>
<beans xmlns="http://www.springframework.org/schema/beans"
       xmlns:context="http://www.springframework.org/schema/context"
       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.xsd
http://www.springframework.org/schema/context
 http://www.springframework.org/schema/context/spring-context.xsd">

    <!--受spring容器管理类, 使用<bean>标签管理

    id="唯一标识"
    -->

    <bean id="userDao" class="com.westos.dao.UserDao">
    </bean>
</beans>

注意:
* bean id是严格区分大小写的 如果id不存在会 NoSuchBeanDefinitionException
* 如果容器中同一个类型的bean有多个,再根据类型获取的话 NoUniqueBeanDefinitionException

2) 创建spring容器

// 根据xml文件应用程序Context容器(上下文)
// classpath指配置文件的位置, 起点有java, resources. 写路径时相对这个起点去写
ClassPathXmlApplicationContext context = new ClassPathXmlApplicationContext("abc/spring.xml");

3) 使用容器内的对象

//        UserDao dao = (UserDao)context.getBean("userDao"); // 根据id获取

UserDao dao = context.getBean(UserDao.class);// 根据类型获取, 找一个类型为UserDao的对象
dao.insert();

4) bean一般需要无参构造,spring会调用它来创建对象
如果没有无参构造,需要给构造方法的参数赋值:

<constructor-arg index="参数下标" value="值"/>

5) 控制对象个数
默认情况下,每个类型的bean在容器中只有一个对象(单例)

多例,每用一次,创建一个新的对象
如果配置多例<bean scope="prototype">

6) 初始化以及销毁方法
<bean init-method="初始化方法名" destroy-method="销毁方法名">
单例对象既会调用初始化,也会调用销毁方法
多例对象,每使用一个多例对象,会调用初始化方法,但所有多例对象都不会调用销毁方法


7) 依赖注入(看做控制反转的一个补充)
tomcat和spring容器都实现了控制反转, 但spring容器有依赖注入的功能,而tomcat没有
DI (dependency injection)

给bean的属性赋值的过程,称为依赖注入,是由spring来管理bean与bean之间的依赖关系

<property name="要注入的属性名" ref="要依赖的bean 的id值"/>

8) 依赖注入的三种方式
方式1: set注入

private UserDao userDao;
public void setUserDao(UserDao userDao) {
    this.userDao = userDao;
}
<property name="要注入的属性名" ref="要依赖的bean 的id值"/>




方法2: 构造注入

public UserService(UserDao userDao) {
    this.userDao = userDao;
}
<constructor-arg index="0" ref="userDao"/>



方法3: 注解注入
@Autowired(spring提供的)  利用这个注解完成属性的赋值,把它加在需要注入的属性上, 或set方法上,或构造方法上

启用该注解

<context:annotation-config/>


@Resource (java官方的注解) 用法与@Autowired类似

 

9) 可以支持将*.properties 注入到spring.xml中

<!--读取properties 文件 location="文件位置"  placeholder 占位符-->
<context:property-placeholder location="classpath:jdbc.properties"/>

<!-- 可以利用 ${key} 获取 *.properties 文件中的值-->
<bean id="productDao" class="com.westos.dao.ProductDao">
    <property name="username" value="${jdbc.username}"/>
    <property name="password" value="${jdbc.password}"/>
</bean>


注解方式 @Value 可以完成这种值注入
@Value("${properties中的key}")

要保证spring.xml的配置文件不要修改,要修改的内容可以配置到*.properties文件中
 

10) 整合mybatis
步骤1:在pom.xml加入依赖
mybatis, mysql, spring-context, logback, druid, junit, spring-jdbc, mybatis-spring

步骤2:把关键对象spring控制反转
连接池对象, sqlSessionFactory, sqlSession
 

① 把数据源对象交给spring容器管理

<bean id="aaa" class="com.alibaba.druid.pool.DruidDataSource">
	<property name="driverClassName" value="${jdbc.driver}"/>
	<property name="url" value="${jdbc.url}"/>
	<property name="username" value="${jdbc.username}"/>
	<property name="password" value="${jdbc.password}"/>
	<property name="maxActive" value="${jdbc.max}"/>
	<property name="minIdle" value="${jdbc.min}"/>
</bean>

② sqlSessionFactory

<bean id="sqlSessionFactory" class="org.mybatis.spring.SqlSessionFactoryBean">
	<!-- 注入连接池 -->
	<property name="dataSource" ref="aaa"/>
	<!-- 注入mapper.xml文件的位置-->
	<property name="mapperLocations" value="classpath:com/westos/mapper/*.xml"/>
</bean>

③ sqlSession (用SqlSessionTemplate得到的SqlSession可以不用我们自己操心事务的管理,以及关闭操作)

<bean id="sql" class="org.mybatis.spring.SqlSessionTemplate">        
	<constructor-arg index="0" ref="sqlSessionFactory"/>
</bean>

步骤3 :使用SqlSession工厂

ClassPathXmlApplicationContext context =
            new ClassPathXmlApplicationContext("abc/spring-mybatis.xml");
SqlSession sqlSession = context.getBean(SqlSession.class);
Map<String, Integer> map = new HashMap<String,Integer>();
map.put("m", 0);
map.put("n", 10);
List<Product> list = sqlSession.selectList("com.westos.mapper.ProductMapper.selectByPage", map);
for (Product product : list) {
	System.out.println(product);
}

猜你喜欢

转载自blog.csdn.net/Wolves_7/article/details/83589501