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容器的生命周期
- Spring 容器根据配置中的 bean 定义中实例化 bean。
- Spring 使用依赖注入填充所有属性,如 bean 中所定义的配置。
- 如果 bean 实现BeanNameAware 接口,则工厂通过传递 bean 的 ID 来调用setBeanName()。
- 如果 bean 实现 BeanFactoryAware 接口,工厂通过传递自身的实例来调用 setBeanFactory()。
- 如果存在与 bean 关联的任何BeanPostProcessors,则调用 preProcessBeforeInitialization() 方法。
- 如果为 bean 指定了 init 方法( 的 init-method 属性),那么将调用它。
- 最后,如果存在与 bean 关联的任何 BeanPostProcessors,则将调 用 postProcessAfterInitialization() 方法。
- 如果 bean 实现DisposableBean 接口,当 spring 容器关闭时,会调用 destory()。
- 如果为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 关联的能力方面有所不同。