spring总结

1.spring framework有哪些不同功能

  • 轻量级:Spring 在代码量和透明度方面都很轻便
  • IOC:控制反转 。通过控制反转实现了松散耦合,对象们给出了他们的依赖,而不是创建或查找依赖的对象们
  • AOP:面向切面编程可以将应用业务逻辑和系统服务分离,以实现高内聚
  • 容器:spring负责创建和管理对象bean的生命周期和配置
  • MVC:对web应用提供了高度可配置性,其他框架的集成也十分方便
  • 事务管理:提供了用于事务管理的通用抽象层,spring事务支持也可以用于容器较少的环境
  • JDBC异常:spring的jdbc抽象层提供了一个异常层次的结构,简化了错误处理策略

2.spring framework模块

  • spring核心容器-spring核心
    • spring core
    • spring bean
    • spel
    • spring context
  • 数据访问/集成 - 该层提供与数据库交互的支持
  • web-该层提供了创建web应用程序的支持
  • AOP-支持面向切面编程
  • instrumentation-该层为类检测和类加载器实现提供支持
  • test-该层为使用junit 和testng进行测试提供支持
  • messaging
  • aspects-该模块为与aspectj的集成提供支持

3.spring应用程序的不同组件

  • 接口:定义功能
  • bean类:包含属性,setter和getter方法,函数等
  • spring面向切面编程aop:提供面向切面编程的功能
  • bean配置文件:包含类的信息以及如何配置他们
  • 用户程序:使用接口

4.依赖注入IOC

IOC容器:

容器创建对象,将他们装配在一起,配置他们并管理他们的完整生命周期,spring容器使用依赖注入来管理组成应用程序的组件,容器通过读取提供的配置元数据来接收对象进行实例化,配置和组装的指令,元数据可以通过xml,java注解或java代码提供。

依赖注入

依赖注入中不必创建对象,但需要描述如何创建他们,描述配置文件中哪些组件需要哪些服务,有ioc容器将他们装配在一起

方式

  • 构造函数注入:没有部分注入、不会覆盖setter属性、任意修改都会创建一个新实例、适用于设置很多属性
  • setter注入:有部分注入、会覆盖setter属性、任意修改不会创建一个新实例、适用于设置少量属性
  • 接口注入

ioc容器

  • BeanFactory:就像一个包含bean集合的工厂类,会在客户端要求时实例化bean
    • 使用懒加载,使用语法显式提供资源对象、不支持国际化、不支持基于依赖的注解
    • bean工厂是工厂模式的一个实现,提供了控制反转功能,用来把应用的配置和依赖从应用代码中分离。
    • 最常见的beanFactory是XmlBeanFactory。根据xml文件中的定义加载beans,该容器从xml文件读取元数据并用它去创建一个完全配置的系统或应用
  • ApplicationContext:扩展了BeanFactory接口,在BeanFactory基础上提供了一些额外功能
    • 使用即时加载、自己创建和管理资源对象、支持国际化、支持基于依赖的注解
    • 实现
      • FileSystemXmlApplicationContext :此容器从一个 XML 文件中加载 beans 的定义,XML Bean 配置文件的全路径名必须提供给它的构造函数。
      • ClassPathXmlApplicationContext:此容器也从一个 XML 文件中加载 beans 的定义,这里,你需要正确设置 classpath 因为这个容器将在 classpath里找 bean 配置。
      • WebXmlApplicationContext:此容器加载一个 XML 文件,此文件定义了一个 WEB 应用的所有 bean。

实现机制

原理为工厂模式加反射机制

5.Beans

spring bean

  • 构成用户应用程序主干的对象
  • Bean由spring ioc容器管理
  • 有spring ioc容器实例化、配置、装配和管理
  • bean是基于用户提供给容器的配置元数据创建

配置方式

  • 基于xml配置
  • 基于注解配置
  • 基于java API配置:通过使用@Bean(与元素相同的角色)和@Configuration实现

bean scope

  • singleton:每个spring ioc容器仅有一个单实例
  • prototype:每次请求都会产生一个新的实例
  • request:每一次http请求都会产生一个新的实例,并且该bean仅在当前http请求内有效
  • session:每一次http请求都会产生一个新的bean,同时该bean仅在当前http session内有效
  • global session:被限定于全局portlet session的声明周期范围内,如果你在web中使用global session作用域来标识bean,那么web会自动当成session类型来使用。

spring bean容器的生命周期

  1. Spring 容器根据配置中的 bean 定义中实例化 bean。
  2. Spring 使用依赖注入填充所有属性,如 bean 中所定义的配置。
  3. 如果 bean 实现BeanNameAware 接口,则工厂通过传递 bean 的 ID 来调用setBeanName()。
  4. 如果 bean 实现 BeanFactoryAware 接口,工厂通过传递自身的实例来调用 setBeanFactory()。
  5. 如果存在与 bean 关联的任何BeanPostProcessors,则调用 preProcessBeforeInitialization() 方法。
  6. 如果为 bean 指定了 init 方法( 的 init-method 属性),那么将调用它。
  7. 最后,如果存在与 bean 关联的任何 BeanPostProcessors,则将调 用 postProcessAfterInitialization() 方法。
  8. 如果 bean 实现DisposableBean 接口,当 spring 容器关闭时,会调用 destory()。
  9. 如果为bean 指定了 destroy 方法( 的 destroy-method 属性),那么将调用它。

spring的内部bean

将bean用作另一个bean的属性时,才能将bean声明为内部bean。

spring装配

当bean在spring容器中组合在一起时,被称为装配或bean装配

自动装配

spring容器可以自动装配bean,即可以通过检查BeanFactory的内容让spring自动解析bean的协作者

模式:

  • no - 这是默认设置,表示没有自动装配。应使用显式 bean 引用进行装配。
  • byName - 它根据 bean 的名称注入对象依赖项。它匹配并装配其属性与 XML文件中由相同名称定义的 bean。
  • byType - 它根据类型注入对象依赖项。如果属性的类型与 XML 文件中的一个 bean 名称匹配,则匹配并装配属性。
  • 构造函数- 它通过调用类的构造函数来注入依赖项。它有大量的参数。
  • autodetect - 首先容器尝试通过构造函数使用 autowire 装配,如果不能,则尝试通过 byType 自动装配。

局限性

  • 覆盖的可能性-使用和设置指定依赖项
  • 基本元数据类型-简单属性无法自动装配
  • 使用明确的装配

6.注解

基于注解的容器配置

  • @Bean:扮演与xml中bean元素相同的角色
  • @Configuration:用于标记一个Java类,该类充当Spring应用程序上下文的配置类。允许通过简单地调用同一个类中其他@Bean方法来定义bean间依赖关系

spring中启动注解装配

通过配置<context:annotation-config/>在配置文件中启用

@Component,@Controller,@Respository,@Service

  • @Component :将 java 类标记为 bean。是任何 Spring 管理组件的通用构造型。spring 的组件扫描机制现在可以将其拾取并将其拉入应用程序环境中。
  • @Controller :将一个类标记为 Spring Web MVC 控制器。标有它的Bean 会自动导入到 IoC 容器中。
  • @Service :是组件注解的特化。它不会对 @Component 注解提供任何其他行为。可以在服务层类中使用 @Service 而不是 @Component,因为它以更好的方式指定了意图。它用于标记一个类,该类充当Spring应用程序上下文中的服务。服务是一个特殊类型的组件,它通常用于执行业务逻辑和数据访问操作。@Service注解表明这个类是一个服务,应该由Spring容器管理。
  • @Repository :这个注解是具有类似用途和功能的 @Component 注解的特化。它为 DAO 提供了额外的好处。它将DAO 导入 IoC 容器,并使未经检查的异常有资格转换为 Spring DataAccessException

@Reqiured

注解主要用在 setter 方法上,它表示该 setter 方法的属性必须要在配置时注入值。否则就会报 BeanInitializationException 异常

@Autowired

@Autowired 可以更准确地控制应该在何处以及如何进行自动装配。此注解用于在 setter 方法,构造函数,具有任意名称或多个参数的属性或方法上自动装配bean。默认情况下,它是类型驱动的注入。

@Qualifier

当创建多个相同类型的 bean 并希望仅使用属性装配其中一个 bean 时,使用@Qualifier 注解和 @Autowired 通过指定应该装配哪个确切的 bean来消除歧义

@RequestMapping

用于将特定 HTTP 请求方法映射到将处理相应请求的控制器中的特定类/方法。此注释可应用于两个级别:

  • 类级别:映射请求的 URL
  • 方法级别:映射 URL 以及 HTTP 请求方法

7.数据访问

spring支持的事务管理类型

  • 程序化事务管理:
  • 声明式事务管理:使用注解或基于xml的配置来管理事务

8.AOP

aop面向切面编程

aspect

由 pointcount 和 advice 组成, 它既包含了横切逻辑的定义, 也包括了连接点的定义. Spring AOP 就是负责实施切面的框架, 它将切面所定义的横切逻辑编织到切面所指定的连接点中. AOP 的工作重心在于如何将增强编织目标对象的连接点上, 这里包含两个工作:

  • 1、如何通过 pointcut 和 advice 定位到特定的 joinpoint 上
  • 2、如何在advice 中编写切面代码.

可以简单地认为, 使用 @Aspect 注解的类就是切面.

切点JoinPoint

程序运行中的一些时间点, 例如一个方法的执行, 或者是一个异常的处理.在 Spring AOP 中, join point 总是方法的执行点。

通知Advice

特定 JoinPoint 处的 Aspect 所采取的动作称为 Advice。Spring AOP 使用一个 Advice 作为拦截器,在 JoinPoint “周围”维护一系列的拦截器。

通知类型

  • Before - 这些类型的 Advice 在 joinpoint 方法之前执行,并使用@Before 注解标记进行配置。
  • After Returning - 这些类型的 Advice 在连接点方法正常执行后执行,并使用@AfterReturning 注解标记进行配置。
  • After Throwing - 这些类型的 Advice 仅在 joinpoint 方法通过抛出异常退出并使用 @AfterThrowing 注解标记配置时执行。
  • After (finally) - 这些类型的 Advice 在连接点方法之后执行,无论方法退出是正常还是异常返回,并使用 @After 注解标记进行配置。
  • Around - 这些类型的 Advice 在连接点之前和之后执行,并使用@Around 注解标记进行配置

**spring aop 中 concern 和 cross-cutting concern 的不同之处 **

  • concern 是想要在应用程序的特定模块中定义的行为。可以定义为想要实现的功能。
  • cross-cutting concern 是一个适用于整个应用的行为,这会影响整个应用程序 。
    例如 ,日志记录 ,安全性和数据传输是应用程序几乎每个模块都需要关注的问题 ,因此它们是跨领域的问题

aop实现方式

  • 静态代理:指使用 AOP 框架提供的命令进行编译,从而在编译阶段就可生成 AOP 代理类,因此也称为编译时增强;

    • 编译时编织(特殊编译器实现)
    • 类加载时编织(特殊的类加载器实现)
  • 动态代理:在运行时在内存中“临时”生成 AOP 动态代理类,因此也被称为运行时增强。

    • JDK 动态代理
    • CGLIB

**Spring AOP and AspectJ AOP 有什么区别 **

Spring AOP 基于动态代理方式实现;AspectJ 基于静态代理方式实现。SpringAOP 仅支持方法级别的 PointCut;提供了完全的 AOP 支持,它还支持属性级别的 PointCut。

**Spring 中的代理 **

将 Advice 应用于目标对象后创建的对象称为代理。在客户端对象的情况下,目标对象和代理对象是相同的。

advice+target object = proxy

**编织(Weaving) **

为了创建一个 advice 对象而链接一个 aspect 和其它应用类型或对象,称为编织(Weaving)。在 Spring AOP 中,编织在运行时执行

9.mvc

mvc框架

Spring Web MVC 框架提供 模型-视图-控制器 架构和随时可用的组件。

**DispatcherServlet 的工作流程 **

  • 1、向服务器发送 HTTP 请求,请求被前端控制器 DispatcherServlet 捕获。
  • 2、 DispatcherServlet 根据 -servlet.xml 中的配置对请求的 URL 进行解析,得到请求资源标识符(URI)。然后根据该 URI,调用 HandlerMapping获得该 Handler 配置的所有相关的对象(包括 Handler 对象以及 Handler 对象对应的拦截器),最后以 HandlerExecutionChain 对象的形式返回。
  • 3、 DispatcherServlet 根据获得的 Handler,选择一个合适的HandlerAdapter。(附注:如果成功获得HandlerAdapter 后,此时将开始执行拦截器的 preHandler(…)方法)。
  • 4、提取 Request 中的模型数据,填充 Handler 入参,开始执行 Handler( Controller)。在填充 Handler 的入参过程中,根据你的配置,Spring 将帮你做一些额外的工作:
    • HttpMessageConveter:将请求消息(如 Json、xml 等数据)转换成一个对象,将对象转换为指定的响应信息。
    • 数据转换:对请求消息进行数据转换。如 String 转换成 Integer、Double 等。
    • 数据根式化:对请求消息进行数据格式化。如将字符串转换成格式化数字或格式化日期等。
    • 数据验证:验证数据的有效性(长度、格式等),验证结果存储到BindingResult 或 Error 中。
  • 5、Handler(Controller)执行完成后,向 DispatcherServlet 返回一个ModelAndView 对象;
  • 6、根据返回的 ModelAndView,选择一个适合的 ViewResolver(必须是已经注册到 Spring 容器中的 ViewResolver)返回给 DispatcherServlet。
  • 7、 ViewResolver 结合 Model 和 View,来渲染视图。
  • 8、视图负责将渲染结果返回给客户端

**WebApplicationContext **

WebApplicationContext 是 ApplicationContext 的扩展。它具有 Web 应用程序所需的一些额外功能。它与普通的 ApplicationContext 在解析主题和决定与哪个 servlet 关联的能力方面有所不同。