2020年3月47个经典Spring面试题详解(附带答案)

前言

这篇文章主要分享了47个Spring经典面试题,提莫以为很不错,本文是在网络上看到的,没有找到准确的原文连接。有些我作了些修改。在这分享也给你们作个参考。正好如今金三银四,但愿对你们有所帮助,有用的话点赞支持!(原文做者若有看到请联系提莫,添加原文出处或者删除)前端

标题是个噱头,不喜能够留言喷我(我脸皮厚,否则也追不到我如今的女友、hhhhhh)java

1.不一样版本的 Spring Framework 有哪些主要功能?

Version Feature
Spring2.5 发布于2007年。这是第一个支持注解的版本。
Spring3.0 发布于2009年。它彻底利用了Java5中的改进,并为JEE6提供了支持。
Spring4.0 发布于2013年。这是第一个彻底支持JAVA8的版本。
spring5.0 发布于2017年。使用JDK 8特性,支持响应式编程,函数式Web框架,对Kotlin支持。

2. 什么是 Spring Framework?

  • Spring 是一个开源应用框架,旨在下降应用程序开发的复杂度。git

  • 它是轻量级、松散耦合的。github

  • 它具备分层体系结构,容许用户选择组件,同时还为 J2EE 应用程序开发提供了一个有凝聚力的框架。web

  • 它能够集成其余框架,如 Structs、Hibernate、EJB 等,因此又称为框架的框架。面试

3. 列举 Spring Framework 的优势。

  • 因为 Spring Frameworks 的分层架构,用户能够自由选择本身须要的组件。正则表达式

  • Spring Framework 支持 POJO(Plain Old Java Object) 编程,从而具有持续集成和可测试性。spring

  • 因为依赖注入和控制反转,JDBC 得以简化。数据库

  • 它是开源免费的。编程

4. Spring Framework 有哪些不一样的功能?

  • 轻量级 - Spring 在代码量和透明度方面都很轻便。

  • IOC - 控制反转

  • AOP - 面向切面编程能够将应用业务逻辑和系统服务分离,以实现高内聚。

  • 容器 - Spring 负责建立和管理对象(Bean)的生命周期和配置。

  • MVC - 对 web 应用提供了高度可配置性,其余框架的集成也十分方便。

  • 事务管理 - 提供了用于事务管理的通用抽象层。Spring 的事务支持也可用于容器较少的环境。

  • JDBC 异常 - Spring 的 JDBC 抽象层提供了一个异常层次结构,简化了错误处理策略。

5. Spring Framework 中有多少个模块,它们分别是什么?

在这里插入图片描述

Spring 核心容器 – 该层基本上是 Spring Framework 的核心。它包含如下模块:

  • Spring Core

  • Spring Bean

  • SpEL (Spring Expression Language)

  • Spring Context

数据访问/集成 – 该层提供与数据库交互的支持。它包含如下模块:

  • JDBC (Java DataBase Connectivity)

  • ORM (Object Relational Mapping)

  • OXM (Object XML Mappers)

  • JMS (Java Messaging Service)

  • Transaction

Web – 该层提供了建立 Web 应用程序的支持。它包含如下模块:AOP – 该层支持面向切面编程

  • Web

  • Web – Servlet

  • Web – Socket

  • Web – Portlet

Instrumentation – 该层为类检测和类加载器实现提供支持。

Test – 该层为使用 JUnit 和 TestNG 进行测试提供支持。

几个杂项模块:

  • Messaging – 该模块为 STOMP 提供支持。它还支持注解编程模型,该模型用于从 WebSocket 客户端路由和处理 STOMP 消息。

  • Aspects – 该模块为与 AspectJ 的集成提供支持。

6. 什么是 Spring 配置文件?

Spring 配置文件是 XML 文件。该文件主要包含类信息。它描述了这些类是如何配置以及相互引入的。可是,XML 配置文件冗长且更加干净。若是没有正确规划和编写,那么在大项目中管理变得很是困难。

7. Spring 应用程序有哪些不一样组件?

Spring 应用通常有如下组件:

  • 接口 - 定义功能。

  • Bean 类 - 它包含属性,setter 和 getter 方法,函数等。

  • Spring 面向切面编程(AOP) - 提供面向切面编程的功能。

  • Bean 配置文件 - 包含类的信息以及如何配置它们。

  • 用户程序 - 它使用接口。

8. 使用 Spring 有哪些方式?

使用 Spring 有如下方式:

  • 做为做为一个成熟的 Spring Web 应用程序。

  • 做为第三方 Web 框架,使用 Spring Frameworks 中间层。

  • 用于远程使用。

  • 做为企业级 Java Bean,它能够包装现有的 POJO(Plain Old Java Objects)。Bean,它能够包装现有的 POJO(Plain Old Java Objects)。

9. 什么是 Spring IOC 容器?

Spring 框架的核心是 Spring 容器。容器建立对象,将它们装配在一块儿,配置它们并管理它们的完整生命周期。Spring 容器使用依赖注入来管理组成应用程序的组件。容器经过读取提供的配置元数据来接收对象进行实例化,配置和组装的指令。该元数据能够经过 XML,Java 注解或 Java 代码提供。

在这里插入图片描述

10. 什么是依赖注入?

在依赖注入中,您没必要建立对象,但必须描述如何建立它们。您不是直接在代码中将组件和服务链接在一块儿,而是描述配置文件中哪些组件须要哪些服务。由 IoC 容器将它们装配在一块儿。

11. 能够经过多少种方式完成依赖注入?

一般,依赖注入能够经过三种方式完成,即:

  • 构造函数注入

  • setter 注入

  • 接口注入

在 Spring Framework 中,仅使用构造函数和 setter 注入。

12. 区分构造函数注入和 setter 注入

构造函数注入 setter注入
没有部分注入 有部分注入
不会覆盖setter属性 会覆盖setter属性
任意修改都会建立一个新实例 任意修改不会建立一个新实例
适用于设置不少属性 适用于设置少许属性

13. spring 中有多少种 IOC 容器?

BeanFactory - BeanFactory 就像一个包含 bean 集合的工厂类。它会在客户端要求时实例化 bean。

ApplicationContext - ApplicationContext 接口扩展了 BeanFactory 接口。它在 BeanFactory 基础上提供了一些额外的功能。

14. 区分 BeanFactory 和 ApplicationContext。

BeanFactory ApplicationContext
它使用懒加载 它使用即时加载
它使用语法显式提供资源对象 它本身建立和管理资源对象
不支持国际化 支持国际化
不支持基于依赖的注解 支持基于依赖的注解

15. 列举 IoC 的一些好处。

IoC 的一些好处是:

  • 它将最小化应用程序中的代码量。

  • 它将使您的应用程序易于测试,由于它不须要单元测试用例中的任何单例或 JNDI 查找机制。

  • 它以最小的影响和最少的侵入机制促进松耦合。

  • 它支持即时的实例化和延迟加载服务。

16. Spring IoC 的实现机制。

Spring 中的 IoC 的实现原理就是工厂模式加反射机制。

示例:

interface Fruit {
     public abstract void eat();
}
class Apple implements Fruit {
    public void eat(){
        System.out.println("Apple");
    }
}
class Orange implements Fruit {
    public void eat(){
        System.out.println("Orange");
    }
}
class Factory {
    public static Fruit getInstance(String ClassName) {
        Fruit f=null;
        try {
            f=(Fruit)Class.forName(ClassName).newInstance();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return f;
    }
}
class Client {
    public static void main(String[] a) {
        Fruit f=Factory.getInstance("io.github.dunwu.spring.Apple");
        if(f!=null){
            f.eat();
        }
    }
}
复制代码

17. 什么是 spring bean?

  • 它们是构成用户应用程序主干的对象。

  • Bean 由 Spring IoC 容器管理。

  • 它们由 Spring IoC 容器实例化,配置,装配和管理。

  • Bean 是基于用户提供给容器的配置元数据建立。

18. spring 提供了哪些配置方式?

基于 xml 配置

bean 所需的依赖项和服务在 XML 格式的配置文件中指定。这些配置文件一般包含许多 bean 定义和特定于应用程序的配置选项。它们一般以 bean 标签开头。例如:

<bean id="studentbean" class="org.edureka.firstSpring.StudentBean">
        <property name="name" value="Edureka"></property>
    </bean>
复制代码

基于注解配置

您能够经过在相关的类,方法或字段声明上使用注解,将 bean 配置为组件类自己,而不是使用 XML 来描述 bean 装配。默认状况下,Spring 容器中未打开注解装配。所以,您须要在使用它以前在 Spring 配置文件中启用它。例如:

<beans>
      <context:annotation-config/>
      <!-- bean definitions go here -->
  </beans>
复制代码

基于 Java API 配置

Spring 的 Java 配置是经过使用@Bean 和 @Configuration 来实现。

  • @Bean 注解扮演与 < bean /> 元素相同的角色。

  • @Configuration 类容许经过简单地调用同一个类中的其余@Bean 方法来定义 bean 间依赖关系。

例如:

public class StudentConfig {   
    @Bean
    public StudentBean myStudent() {
        return new StudentBean();
    }
}
复制代码

19. spring 支持集中 bean scope?

Spring bean 支持 5 种 scope:

  • Singleton - 每一个 Spring IoC 容器仅有一个单实例。

  • Prototype - 每次请求都会产生一个新的实例。

  • Request - 每一次 HTTP 请求都会产生一个新的实例,而且该 bean 仅在当前 HTTP 请求内有效。

  • Session - 每一次 HTTP 请求都会产生一个新的 bean,同时该 bean 仅在当前 HTTP session 内有效。

  • Global-session - 相似于标准的 HTTP Session 做用域,不过它仅仅在基于 portlet 的 web 应用中才有意义。Portlet 规范定义了全局 Session 的概念,它被全部构成某个 portlet web 应用的各类不一样的 portlet 所共享。在 global session 做用域中定义的 bean 被限定于全局 portlet Session 的生命周期范围内。若是你在 web 中使用 global session 做用域来标识 bean,那么 web 会自动当成 session 类型来使用。

仅当用户使用支持 Web 的 ApplicationContext 时,最后三个才可用。

20. spring bean 容器的生命周期是什么样的?

spring bean 容器的生命周期流程以下:

  • Spring 容器根据配置中的 bean 定义中实例化 bean。

  • Spring 使用依赖注入填充全部属性,如 bean 中所定义的配置。

  • 若是 bean 实现 BeanNameAware 接口,则工厂经过传递 bean 的 ID 来调用 setBeanName()。

  • 若是 bean 实现 BeanFactoryAware 接口,工厂经过传递自身的实例来调用 setBeanFactory()。

  • 若是存在与 bean 关联的任何 BeanPostProcessors,则调用 preProcessBeforeInitialization() 方法。

-若是为 bean 指定了 init 方法( < bean> 的 init-method 属性),那么将调用它。

  • 最后,若是存在与 bean 关联的任何 BeanPostProcessors,则将调用 postProcessAfterInitialization() 方法。

  • 若是 bean 实现 DisposableBean 接口,当 spring 容器关闭时,会调用 destory()。

  • 若是为 bean 指定了 destroy 方法( < bean> 的 destroy-method 属性),那么将调用它。

在这里插入图片描述

21. 什么是 spring 的内部 bean?

只有将 bean 用做另外一个 bean 的属性时,才能将 bean 声明为内部 bean。为了定义 bean,Spring 的基于 XML 的配置元数据在 < property> 或 < constructor-arg> 中提供了 < bean> 元素的使用。内部 bean 老是匿名的,它们老是做为原型。

例如,假设咱们有一个 Student 类,其中引用了 Person 类。这里咱们将只建立一个 Person 类实例并在 Student 中使用它。

Student.java

public class Student {
    private Person person;
    //Setters and Getters
}
public class Person {
    private String name;
    private String address;
    //Setters and Getters
}
bean.xml

<bean id=“StudentBean" class="com.edureka.Student"> <property name="person"> <!--This is inner bean --> <bean class="com.edureka.Person"> <property name="name" value=“Scott"></property>
                <property name="address" value=“Bangalore"></property> </bean> </property> </bean> 复制代码

22. 什么是 spring 装配

当 bean 在 Spring 容器中组合在一块儿时,它被称为装配或 bean 装配。 Spring 容器须要知道须要什么 bean 以及容器应该如何使用依赖注入来将 bean 绑定在一块儿,同时装配 bean。

23. 自动装配有哪些方式?

Spring 容器可以自动装配 bean。也就是说,能够经过检查 BeanFactory 的内容让 Spring 自动解析 bean 的协做者。

自动装配的不一样模式:

  • no - 这是默认设置,表示没有自动装配。应使用显式 bean 引用进行装配。

  • byName - 它根据 bean 的名称注入对象依赖项。它匹配并装配其属性与 XML 文件中由相同名称定义的 bean。

  • byType - 它根据类型注入对象依赖项。若是属性的类型与 XML 文件中的一个 bean 名称匹配,则匹配并装配属性。

  • 构造函数 - 它经过调用类的构造函数来注入依赖项。它有大量的参数。

  • autodetect - 首先容器尝试经过构造函数使用 autowire 装配,若是不能,则尝试经过 byType 自动装配。

24. 自动装配有什么局限?

  • 覆盖的可能性 - 您始终可使用 和 设置指定依赖项,这将覆盖自动装配。

  • 基本元数据类型 - 简单属性(如原数据类型,字符串和类)没法自动装配。

  • 使人困惑的性质 - 老是喜欢使用明确的装配,由于自动装配不太精确。

25. 你用过哪些重要的 Spring 注解?

  • @Controller - 用于 Spring MVC 项目中的控制器类。

  • @Service - 用于服务类。

  • @RequestMapping - 用于在控制器处理程序方法中配置 URI 映射。

  • @ResponseBody - 用于发送 Object 做为响应,一般用于发送 XML 或 JSON 数据做为响应。

  • @PathVariable - 用于将动态值从 URI 映射处处理程序方法参数。

  • @Autowired - 用于在 spring bean 中自动装配依赖项。

  • @Qualifier - 使用 @Autowired 注解,以免在存在多个 bean 类型实例时出现混淆。

  • @Scope - 用于配置 spring bean 的范围。

  • @Configuration,@ComponentScan 和 @Bean - 用于基于 java 的配置。

  • @Aspect,@Before,@After,@Around,@Pointcut - 用于切面编程(AOP)。

26. 如何在 spring 中启动注解装配?

默认状况下,Spring 容器中未打开注解装配。所以,要使用基于注解装配,咱们必须经过配置 <context:annotation-config /> 元素在 Spring 配置文件中启用它。

27. @Component, @Controller, @Repository, @Service 有何区别?

  • @Component:这将 java 类标记为 bean。它是任何 Spring 管理组件的通用构造型。spring 的组件扫描机制如今能够将其拾取并将其拉入应用程序环境中。

  • @Controller:这将一个类标记为 Spring Web MVC 控制器。标有它的 Bean 会自动导入到 IoC 容器中。

  • @Service:此注解是组件注解的特化。它不会对 @Component 注解提供任何其余行为。您能够在服务层类中使用 @Service 而不是 @Component,由于它以更好的方式指定了意图。

  • @Repository:这个注解是具备相似用途和功能的 @Component 注解的特化。它为 DAO 提供了额外的好处。它将 DAO 导入 IoC 容器,并使未经检查的异常有资格转换为 Spring DataAccessException。

28. @Required 注解有什么用?

@Required 应用于 bean 属性 setter 方法。此注解仅指示必须在配置时使用 bean 定义中的显式属性值或使用自动装配填充受影响的 bean 属性。若是还没有填充受影响的 bean 属性,则容器将抛出 BeanInitializationException。

示例:

public class Employee {
    private String name;
    @Required
    public void setName(String name){
        this.name=name;
    }
    public string getName(){
        return name;
    }
}
复制代码

29.@Autowired 注解有什么用?

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

public class Employee {
    private String name;
    @Autowired
    public void setName(String name) {
        this.name=name;
    }
    public string getName(){
        return name;
    }
}
复制代码

30. @Qualifier 注解有什么用?

当您建立多个相同类型的 bean 并但愿仅使用属性装配其中一个 bean 时,您可使用@Qualifier 注解和 @Autowired 经过指定应该装配哪一个确切的 bean 来消除歧义。

例如,这里咱们分别有两个类,Employee 和 EmpAccount。在 EmpAccount 中,使用@Qualifier 指定了必须装配 id 为 emp1 的 bean。

Employee.java

public class Employee {
    private String name;
    @Autowired
    public void setName(String name) {
        this.name=name;
    }
    public string getName() {
        return name;
    }
}
复制代码

EmpAccount.java

public class EmpAccount {
    private Employee emp;
 
    @Autowired
    @Qualifier(emp1)
    public void showName() {
        System.out.println(“Employee name : ”+emp.getName);
    }
}
复制代码

31.@RequestMapping 注解有什么用?

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

  • 类级别:映射请求的 URL

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

32. spring DAO 有什么用?

Spring DAO 使得 JDBC,Hibernate 或 JDO 这样的数据访问技术更容易以一种统一的方式工做。这使得用户容易在持久性技术之间切换。它还容许您在编写代码时,无需考虑捕获每种技术不一样的异常。

33. 列举 Spring DAO 抛出的异常。

在这里插入图片描述

34. spring JDBC API 中存在哪些类?

  • JdbcTemplate

  • SimpleJdbcTemplate

  • NamedParameterJdbcTemplate

  • SimpleJdbcInsert

  • SimpleJdbcCall

35. 使用 Spring 访问 Hibernate 的方法有哪些?

咱们能够经过两种方式使用 Spring 访问 Hibernate:

  • 使用 Hibernate 模板和回调进行控制反转

  • 扩展 HibernateDAOSupport 并应用 AOP 拦截器节点

36. 列举 spring 支持的事务管理类型

Spring 支持两种类型的事务管理:

  • 程序化事务管理:在此过程当中,在编程的帮助下管理事务。它为您提供极大的灵活性,但维护起来很是困难。

  • 声明式事务管理:在此,事务管理与业务代码分离。仅使用注解或基于 XML 的配置来管理事务。

spring 支持哪些 ORM 框架

  • Hibernate

  • iBatis

  • JPA

  • JDO

  • OJB

37.什么是 AOP?

AOP(Aspect-Oriented Programming), 即 面向切面编程, 它与 OOP( Object-Oriented Programming, 面向对象编程) 相辅相成, 提供了与 OOP 不一样的抽象软件结构的视角. 在 OOP 中, 咱们以类(class)做为咱们的基本单元, 而 AOP 中的基本单元是 Aspect(切面)

38. AOP 中的 Aspect、Advice、Pointcut、JointPoint 和 Advice 参数分别是什么?

在这里插入图片描述

  • Aspect - Aspect 是一个实现交叉问题的类,例如事务管理。方面能够是配置的普通类,而后在 Spring Bean 配置文件中配置,或者咱们可使用 Spring AspectJ 支持使用 @Aspect 注解将类声明为 Aspect。

  • Advice - Advice 是针对特定 JoinPoint 采起的操做。在编程方面,它们是在应用程序中达到具备匹配切入点的特定 JoinPoint 时执行的方法。您能够将 Advice 视为 Spring 拦截器(Interceptor)或 Servlet 过滤器(filter)。

  • Advice Arguments - 咱们能够在 advice 方法中传递参数。咱们能够在切入点中使用 args() 表达式来应用于与参数模式匹配的任何方法。若是咱们使用它,那么咱们须要在肯定参数类型的 advice 方法中使用相同的名称。

  • Pointcut - Pointcut 是与 JoinPoint 匹配的正则表达式,用于肯定是否须要执行 Advice。 Pointcut 使用与 JoinPoint 匹配的不一样类型的表达式。Spring 框架使用 AspectJ Pointcut 表达式语言来肯定将应用通知方法的 JoinPoint。

  • JoinPoint - JoinPoint 是应用程序中的特定点,例如方法执行,异常处理,更改对象变量值等。在 Spring AOP 中,JoinPoint 始终是方法的执行器。

39. 什么是通知(Advice)?

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

40. 有哪些类型的通知(Advice)?

  • Before - 这些类型的 Advice 在 joinpoint 方法以前执行,并使用 @Before 注解标记进行配置。

  • After Returning - 这些类型的 Advice 在链接点方法正常执行后执行,并使用@AfterReturning 注解标记进行配置。

  • After Throwing - 这些类型的 Advice 仅在 joinpoint 方法经过抛出异常退出并使用 @AfterThrowing 注解标记配置时执行。

  • After (finally) - 这些类型的 Advice 在链接点方法以后执行,不管方法退出是正常仍是异常返回,并使用 @After 注解标记进行配置。

  • Around - 这些类型的 Advice 在链接点以前和以后执行,并使用 @Around 注解标记进行配置。

41. 指出在 spring aop 中 concern 和 cross-cutting concern 的不一样之处。

concern 是咱们想要在应用程序的特定模块中定义的行为。它能够定义为咱们想要实现的功能。

cross-cutting concern 是一个适用于整个应用的行为,这会影响整个应用程序。例如,日志记录,安全性和数据传输是应用程序几乎每一个模块都须要关注的问题,所以它们是跨领域的问题。

41. AOP 有哪些实现方式?

实现 AOP 的技术,主要分为两大类:

  • 静态代理 - 指使用 AOP 框架提供的命令进行编译,从而在编译阶段就可生成 AOP 代理类,所以也称为编译时加强;
  1. 编译时编织(特殊编译器实现)

  2. 类加载时编织(特殊的类加载器实现)。

  • 动态代理 - 在运行时在内存中“临时”生成 AOP 动态代理类,所以也被称为运行时加强。
  1. JDK 动态代理

  2. CGLIB

42. Spring AOP and AspectJ AOP 有什么区别?

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

43. 如何理解 Spring 中的代理?

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

`Advice + Target Object = Proxy`
复制代码

44. 什么是编织(Weaving)?

为了建立一个 advice 对象而连接一个 aspect 和其它应用类型或对象,称为编织(Weaving)。在 Spring AOP 中,编织在运行时执行。请参考下图:

在这里插入图片描述

45. Spring MVC 框架有什么用?

Spring Web MVC 框架提供 模型-视图-控制器 架构和随时可用的组件,用于开发灵活且松散耦合的 Web 应用程序。 MVC 模式有助于分离应用程序的不一样方面,如输入逻辑,业务逻辑和 UI 逻辑,同时在全部这些元素之间提供松散耦合。

46. 描述一下 DispatcherServlet 的工做流程

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 将帮你作一些额外的工做:Handler(Controller)执行完成后,向 DispatcherServlet 返回一个 ModelAndView 对象;

HttpMessageConveter : 将请求消息(如 Json、xml 等数据)转换成一个对象,将对象转换为指定的响应信息。

数据转换 :对请求消息进行数据转换。如 String 转换成 Integer 、 Double 等。

数据根式化 :对请求消息进行数据格式化。 如将字符串转换成格式化数字或格式化日期等。

数据验证 : 验证数据的有效性(长度、格式等),验证结果存储到 BindingResult 或 Error 中。

  1. 根据返回的 ModelAndView ,选择一个适合的 ViewResolver (必须是已经注册到 Spring 容器中的 ViewResolver )返回给 DispatcherServlet 。

  2. ViewResolver 结合 Model 和 View ,来渲染视图。

  3. 视图负责将渲染结果返回给客户端。

47. 介绍一下 WebApplicationContext

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

最后附上学习图谱:

ps:资源过大,有须要的话请关注公众号:JavaTimo 能够回复:spring 领取。

还有如今整理好了 1000 道多家公司 java 面试题 400 多页 pdf 文档,都已经分专题整理好了。还有几百页的 Java 核心知识点 PDF,和海量的学习资料

好了各位, 本文到这里就结束了! 若是本文有任何错误,请批评指教,不胜感激 !

相关文章
相关标签/搜索