网站弹窗广告代码,武昌做网站哪家好,合肥搜索引擎推广,地方网站域名用全拼转载自 Spring Boot面试题#xff08;2020最新版#xff09;
概述
什么是 Spring Boot#xff1f;
Spring Boot 是 Spring 开源组织下的子项目#xff0c;是 Spring 组件一站式解决方案#xff0c;主要是简化了使用 Spring 的难度#xff0c;简省了繁重的配置#x…转载自 Spring Boot面试题2020最新版
概述
什么是 Spring Boot
Spring Boot 是 Spring 开源组织下的子项目是 Spring 组件一站式解决方案主要是简化了使用 Spring 的难度简省了繁重的配置提供了各种启动器开发者能快速上手。 Spring Boot 有哪些优点
Spring Boot 主要有如下优点 容易上手提升开发效率为 Spring 开发提供一个更快、更广泛的入门体验。 开箱即用远离繁琐的配置。 提供了一系列大型项目通用的非业务性功能例如内嵌服务器、安全管理、运行数据监控、运行状况检查和外部化配置等。 没有代码生成也不需要XML配置。 避免大量的 Maven 导入和各种版本冲突。 Spring Boot 的核心注解是哪个它主要由哪几个注解组成的
启动类上面的注解是SpringBootApplication它也是 Spring Boot 的核心注解主要组合包含了以下 3 个注解 启动类上面的注解是SpringBootApplication它也是 Spring Boot 的核心注解主要组合包含了以下 3 个注解 SpringBootConfiguration组合了 Configuration 注解实现配置文件的功能。 EnableAutoConfiguration打开自动配置的功能也可以关闭某个自动配置的选项如关闭数据源自动配置功能SpringBootApplication(exclude{DataSourceAutoConfiguration.class})
ComponentScanSpring组件扫描。 配置
什么是 JavaConfig
Spring JavaConfig 是 Spring 社区的产品它提供了配置 Spring IoC 容器的纯Java 方法。因此它有助于避免使用 XML 配置。使用 JavaConfig 的优点在于 1面向对象的配置。由于配置被定义为 JavaConfig 中的类因此用户可以充分利用 Java 中的面向对象功能。一个配置类可以继承另一个重写它的Bean 方法等。 2减少或消除 XML 配置。基于依赖注入原则的外化配置的好处已被证明。但是许多开发人员不希望在 XML 和 Java 之间来回切换。JavaConfig 为开发人员提供了一种纯 Java 方法来配置与 XML 配置概念相似的 Spring 容器。从技术角度来讲只使用 JavaConfig 配置类来配置容器是可行的但实际上很多人认为将JavaConfig 与 XML 混合匹配是理想的。 3类型安全和重构友好。JavaConfig 提供了一种类型安全的方法来配置 Spring容器。由于 Java 5.0 对泛型的支持现在可以按类型而不是按名称检索 bean不需要任何强制转换或基于字符串的查找。
Spring Boot 自动配置原理是什么
注解 EnableAutoConfiguration, Configuration, ConditionalOnClass 就是自动配置的核心
EnableAutoConfiguration 给容器导入META-INF/spring.factories 里定义的自动配置类。
筛选有效的自动配置类。
每一个自动配置类结合对应的 xxxProperties.java 读取配置文件进行自动配置功能 你如何理解 Spring Boot 配置加载顺序
在 Spring Boot 里面可以使用以下几种方式来加载配置。
1properties文件
2YAML文件
3系统环境变量
4命令行参数
等等……
什么是 YAML
YAML 是一种人类可读的数据序列化语言。它通常用于配置文件。与属性文件相比如果我们想要在配置文件中添加复杂的属性YAML 文件就更加结构化而且更少混淆。可以看出 YAML 具有分层配置数据。
YAML 配置的优势在哪里 ?
YAML 现在可以算是非常流行的一种配置文件格式了无论是前端还是后端都可以见到 YAML 配置。那么 YAML 配置和传统的 properties 配置相比到底有哪些优势呢 配置有序在一些特殊的场景下配置有序很关键 支持数组数组中的元素可以是基本数据类型也可以是对象 简洁
相比 properties 配置文件YAML 还有一个缺点就是不支持PropertySource 注解导入自定义的 YAML 配置。
Spring Boot 是否可以使用 XML 配置 ?
Spring Boot 推荐使用 Java 配置而非 XML 配置但是 Spring Boot 中也可以使用 XML 配置通过 ImportResource 注解可以引入一个 XML 配置。
spring boot 核心配置文件是什么bootstrap.properties 和 application.properties 有何区别 ?
单纯做 Spring Boot 开发可能不太容易遇到 bootstrap.properties 配置文件但是在结合 Spring Cloud 时这个配置就会经常遇到了特别是在需要加载一些远程配置文件的时侯。
spring boot 核心的两个配置文件 bootstrap (. yml 或者 . properties)boostrap 由父 ApplicationContext 加载的比 applicaton 优先加载配置在应用程序上下文的引导阶段生效。一般来说我们在 Spring Cloud Config 或者 Nacos 中会用到它。且 boostrap 里面的属性不能被覆盖 application (. yml 或者 . properties)由ApplicatonContext 加载用于 spring boot 项目的自动化配置。 什么是 Spring Profiles
Spring Profiles 允许用户根据配置文件devtestprod 等来注册 bean。因此当应用程序在开发中运行时只有某些 bean 可以加载而在 PRODUCTION中某些其他 bean 可以加载。假设我们的要求是 Swagger 文档仅适用于 QA 环境并且禁用所有其他文档。这可以使用配置文件来完成。Spring Boot 使得使用配置文件非常简单。 如何在自定义端口上运行 Spring Boot 应用程序
为了在自定义端口上运行 Spring Boot 应用程序您可以在application.properties 中指定端口。server.port 8090
安全
如何实现 Spring Boot 应用程序的安全性
为了实现 Spring Boot 的安全性我们使用 spring-boot-starter-security 依赖项并且必须添加安全配置。它只需要很少的代码。配置类将必须扩展WebSecurityConfigurerAdapter 并覆盖其方法。
比较一下 Spring Security 和 Shiro 各自的优缺点 ?
由于 Spring Boot 官方提供了大量的非常方便的开箱即用的 Starter 包括 Spring Security 的 Starter 使得在 Spring Boot 中使用 Spring Security 变得更加容易甚至只需要添加一个依赖就可以保护所有的接口所以如果是 Spring Boot 项目一般选择 Spring Security 。当然这只是一个建议的组合单纯从技术上来说无论怎么组合都是没有问题的。Shiro 和 Spring Security 相比主要有如下一些特点 Spring Security 是一个重量级的安全管理框架Shiro 则是一个轻量级的安全管理框架 Spring Security 概念复杂配置繁琐Shiro 概念简单、配置简单 Spring Security 功能强大Shiro 功能简单
Spring Boot 中如何解决跨域问题 ?
跨域可以在前端通过 JSONP 来解决但是 JSONP 只可以发送 GET 请求无法发送其他类型的请求在 RESTful 风格的应用中就显得非常鸡肋因此我们推荐在后端通过 CORSCross-origin resource sharing 来解决跨域问题。这种解决方案并非 Spring Boot 特有的在传统的 SSM 框架中就可以通过 CORS 来解决跨域问题只不过之前我们是在 XML 文件中配置 CORS 现在可以通过实现WebMvcConfigurer接口然后重写addCorsMappings方法解决跨域问题。 Configurationpublic class CorsConfig implements WebMvcConfigurer {Override public void addCorsMappings(CorsRegistry registry) { registry.addMapping(/**) .allowedOrigins(*) .allowCredentials(true) .allowedMethods(GET, POST, PUT, DELETE, OPTIONS) .maxAge(3600); }
}
项目中前后端分离部署所以需要解决跨域的问题。
我们使用cookie存放用户登录的信息在spring拦截器进行权限控制当权限不符合时直接返回给用户固定的json结果。
当用户登录以后正常使用当用户退出登录状态时或者token过期时由于拦截器和跨域的顺序有问题出现了跨域的现象。
我们知道一个http请求先走filter到达servlet后才进行拦截器的处理如果我们把cors放在filter里就可以优先于权限拦截器执行。 Configurationpublic class CorsConfig {Bean public CorsFilter corsFilter() { CorsConfiguration corsConfiguration new CorsConfiguration(); corsConfiguration.addAllowedOrigin(*); corsConfiguration.addAllowedHeader(*); corsConfiguration.addAllowedMethod(*); corsConfiguration.setAllowCredentials(true); UrlBasedCorsConfigurationSource urlBasedCorsConfigurationSource new UrlBasedCorsConfigurationSource(); urlBasedCorsConfigurationSource.registerCorsConfiguration(/**, corsConfiguration); return new CorsFilter(urlBasedCorsConfigurationSource); }
}
什么是 CSRF 攻击
CSRF 代表跨站请求伪造。这是一种攻击迫使最终用户在当前通过身份验证的Web 应用程序上执行不需要的操作。CSRF 攻击专门针对状态改变请求而不是数据窃取因为攻击者无法查看对伪造请求的响应。
监视器
Spring Boot 中的监视器是什么
Spring boot actuator 是 spring 启动框架中的重要功能之一。Spring boot 监视器可帮助您访问生产环境中正在运行的应用程序的当前状态。有几个指标必须在生产环境中进行检查和监控。即使一些外部应用程序可能正在使用这些服务来向相关人员触发警报消息。监视器模块公开了一组可直接作为 HTTP URL 访问的REST 端点来检查状态。 如何在 Spring Boot 中禁用 Actuator 端点安全性
默认情况下所有敏感的 HTTP 端点都是安全的只有具有 ACTUATOR 角色的用户才能访问它们。安全性是使用标准的 HttpServletRequest.isUserInRole 方法实施的。我们可以使用来禁用安全性。只有在执行机构端点在防火墙后访问时才建议禁用安全性。 我们如何监视所有 Spring Boot 微服务
Spring Boot 提供监视器端点以监控各个微服务的度量。这些端点对于获取有关应用程序的信息如它们是否已启动以及它们的组件如数据库等是否正常运行很有帮助。但是使用监视器的一个主要缺点或困难是我们必须单独打开应用程序的知识点以了解其状态或健康状况。想象一下涉及 50 个应用程序的微服务管理员将不得不击中所有 50 个应用程序的执行终端。为了帮助我们处理这种情况我们将使用位于的开源项目。它建立在 Spring Boot Actuator 之上它提供了一个 Web UI使我们能够可视化多个应用程序的度量。 整合第三方项目
什么是 WebSockets
WebSocket 是一种计算机通信协议通过单个 TCP 连接提供全双工通信信道。 1、WebSocket 是双向的 -使用 WebSocket 客户端或服务器可以发起消息发送。 2、WebSocket 是全双工的 -客户端和服务器通信是相互独立的。 3、单个 TCP 连接 -初始连接使用 HTTP然后将此连接升级到基于套接字的连接。然后这个单一连接用于所有未来的通信 4、Light -与 http 相比WebSocket 消息数据交换要轻得多。
什么是 Spring Data ?
Spring Data 是 Spring 的一个子项目。用于简化数据库访问支持NoSQL 和 关系数据存储。其主要目标是使数据库的访问变得方便快捷。Spring Data 具有如下特点
SpringData 项目支持 NoSQL 存储 MongoDB 文档数据库 Neo4j图形数据库 Redis键/值存储 Hbase列族数据库
SpringData 项目所支持的关系数据存储技术 JDBC JPA
Spring Data Jpa 致力于减少数据访问层 (DAO) 的开发量. 开发者唯一要做的就是声明持久层的接口其他都交给 Spring Data JPA 来帮你完成Spring Data JPA 通过规范方法的名字根据符合规范的名字来确定方法需要实现什么样的逻辑。 什么是 Spring Batch
Spring Boot Batch 提供可重用的函数这些函数在处理大量记录时非常重要包括日志/跟踪事务管理作业处理统计信息作业重新启动跳过和资源管理。它还提供了更先进的技术服务和功能通过优化和分区技术可以实现极高批量和高性能批处理作业。简单以及复杂的大批量批处理作业可以高度可扩展的方式利用框架处理重要大量的信息。 什么是 FreeMarker 模板
FreeMarker 是一个基于 Java 的模板引擎最初专注于使用 MVC 软件架构进行动态网页生成。使用 Freemarker 的主要优点是表示层和业务层的完全分离。程序员可以处理应用程序代码而设计人员可以处理 html 页面设计。最后使用freemarker 可以将这些结合起来给出最终的输出页面。 如何集成 Spring Boot 和 ActiveMQ
对于集成 Spring Boot 和 ActiveMQ我们使用依赖关系。它只需要很少的配置并且不需要样板代码。
什么是 Apache Kafka
Apache Kafka 是一个分布式发布 - 订阅消息系统。它是一个可扩展的容错的发布 - 订阅消息系统它使我们能够构建分布式应用程序。这是一个 Apache 顶级项目。Kafka 适合离线和在线消息消费。
什么是 Swagger你用 Spring Boot 实现了它吗
Swagger 广泛用于可视化 API使用 Swagger UI 为前端开发人员提供在线沙箱。Swagger 是用于生成 RESTful Web 服务的可视化表示的工具规范和完整框架实现。它使文档能够以与服务器相同的速度更新。当通过 Swagger 正确定义时消费者可以使用最少量的实现逻辑来理解远程服务并与其进行交互。因此Swagger消除了调用服务时的猜测。
前后端分离如何维护接口文档 ?
前后端分离开发日益流行大部分情况下我们都是通过 Spring Boot 做前后端分离开发前后端分离一定会有接口文档不然会前后端会深深陷入到扯皮中。一个比较笨的方法就是使用 word 或者 md 来维护接口文档但是效率太低接口一变所有人手上的文档都得变。在 Spring Boot 中这个问题常见的解决方案是 Swagger 使用 Swagger 我们可以快速生成一个接口文档网站接口一旦发生变化文档就会自动更新所有开发工程师访问这一个在线网站就可以获取到最新的接口文档非常方便。 其他
如何重新加载 Spring Boot 上的更改而无需重新启动服务器Spring Boot项目如何热部署
这可以使用 DEV 工具来实现。通过这种依赖关系您可以节省任何更改嵌入式tomcat 将重新启动。Spring Boot 有一个开发工具DevTools模块它有助于提高开发人员的生产力。Java 开发人员面临的一个主要挑战是将文件更改自动部署到服务器并自动重启服务器。开发人员可以重新加载 Spring Boot 上的更改而无需重新启动服务器。这将消除每次手动部署更改的需要。Spring Boot 在发布它的第一个版本时没有这个功能。这是开发人员最需要的功能。DevTools 模块完全满足开发人员的需求。该模块将在生产环境中被禁用。它还提供 H2 数据库控制台以更好地测试应用程序。 dependency groupIdorg.springframework.boot/groupId artifactIdspring-boot-devtools/artifactId/dependency
您使用了哪些 starter maven 依赖项
使用了下面的一些依赖项
spring-boot-starter-activemq
spring-boot-starter-security
这有助于增加更少的依赖关系并减少版本的冲突。
Spring Boot 中的 starter 到底是什么 ?
首先这个 Starter 并非什么新的技术点基本上还是基于 Spring 已有功能来实现的。首先它提供了一个自动化配置类一般命名为 XXXAutoConfiguration 在这个配置类中通过条件注解来决定一个配置是否生效条件注解就是 Spring 中原本就有的然后它还会提供一系列的默认配置也允许开发者根据实际情况自定义相关配置然后通过类型安全的属性注入将这些配置属性注入进来新注入的属性会代替掉默认属性。正因为如此很多第三方框架我们只需要引入依赖就可以直接使用了。当然开发者也可以自定义 Starter spring-boot-starter-parent 有什么用 ?
我们都知道新创建一个 Spring Boot 项目默认都是有 parent 的这个 parent 就是 spring-boot-starter-parent spring-boot-starter-parent 主要有如下作用 定义了 Java 编译版本为 1.8 。 使用 UTF-8 格式编码。 继承自 spring-boot-dependencies这个里边定义了依赖的版本也正是因为继承了这个依赖所以我们在写依赖时才不需要写版本号。 执行打包操作的配置。 自动化的资源过滤。 自动化的插件配置。 针对 application.properties 和 application.yml 的资源过滤包括通过 profile 定义的不同环境的配置文件例如 application-dev.properties 和 application-dev.yml。
Spring Boot 打成的 jar 和普通的 jar 有什么区别 ?
Spring Boot 项目最终打包成的 jar 是可执行 jar 这种 jar 可以直接通过 java -jar xxx.jar 命令来运行这种 jar 不可以作为普通的 jar 被其他项目依赖即使依赖了也无法使用其中的类。 Spring Boot 的 jar 无法被其他项目依赖主要还是他和普通 jar 的结构不同。普通的 jar 包解压后直接就是包名包里就是我们的代码而 Spring Boot 打包成的可执行 jar 解压后在 \BOOT-INF\classes 目录下才是我们的代码因此无法被直接引用。如果非要引用可以在 pom.xml 文件中增加配置将 Spring Boot 项目打包成两个 jar 一个可执行一个可引用。 运行 Spring Boot 有哪几种方式
1打包用命令或者放到容器中运行
2用 Maven/ Gradle 插件运行
3直接执行 main 方法运行
Spring Boot 需要独立的容器运行吗
可以不需要内置了 Tomcat/ Jetty 等容器。
开启 Spring Boot 特性有哪几种方式
1继承spring-boot-starter-parent项目
2导入spring-boot-dependencies项目依赖
如何使用 Spring Boot 实现异常处理
Spring 提供了一种使用 ControllerAdvice 处理异常的非常有用的方法。我们通过实现一个 ControlerAdvice 类来处理控制器类抛出的所有异常。
如何使用 Spring Boot 实现分页和排序
使用 Spring Boot 实现分页非常简单。使用 Spring Data-JPA 可以实现将可分页的传递给存储库方法。
微服务中如何实现 session 共享 ?
在微服务中一个完整的项目被拆分成多个不相同的独立的服务各个服务独立部署在不同的服务器上各自的 session 被从物理空间上隔离开了但是经常我们需要在不同微服务之间共享 session 常见的方案就是 Spring Session Redis 来实现 session 共享。将所有微服务的 session 统一保存在 Redis 上当各个微服务对 session 有相关的读写操作时都去操作 Redis 上的 session 。这样就实现了 session 共享Spring Session 基于 Spring 中的代理过滤器实现使得 session 的同步操作对开发人员而言是透明的非常简便。 Spring Boot 中如何实现定时任务 ?
定时任务也是一个常见的需求Spring Boot 中对于定时任务的支持主要还是来自 Spring 框架。
在 Spring Boot 中使用定时任务主要有两种不同的方式一个就是使用 Spring 中的 Scheduled 注解另一个则是使用第三方框架 Quartz。
使用 Spring 中的 Scheduled 的方式主要通过 Scheduled 注解来实现。
使用 Quartz 则按照 Quartz 的方式定义 Job 和 Trigger 即可。 原文地址https://blog.csdn.net/ThinkWon/article/details/104397299 作者ThinkWon 面试专场 Redis面试题2020最新版 Tomcat面试题2020最新版 Java虚拟机(JVM)面试题2020最新版 Spring Cloud面试题2020最新版 MySQL数据库面试题2020最新版 消息中间件MQ与RabbitMQ面试题2020最新版 Java并发编程面试题2020最新版 Netty面试题2020最新版 Zookeeper超详细的面试题 Java经典面试题整理及答案详解一 面试官问为什么需要消息队列使用消息队列有什么好处 BAT大厂招聘Java 程序员的技术标准你达到要求了吗 别再说你不会分布式了面试官能问的都在这了 Spring MVC 面经 Java面试----2018年MyBatis常见实用面试题整理 《图解HTTP》面试知道这些就差不多了 Spring经典面试题总结 面试史上最全多线程面试题