11.Spring Boot高频面试题

目录


Java Web面试题目录清单(高频面试题型)(点击进入…)



Spring Boot高频面试题

1.什么是Spring Boot?

Spring Boot是Spring开源组织下的子项目,是Spring组件一站式解决方案,主要是简化了使用Spring的难度,简省了繁重的配置,提供了各种启动器,开发者能快速上手


2.Spring Boot优点?

(1)容易上手,提升开发效率,为Spring开发提供一个更快、更广泛的入门体验
(2)开箱即用,远离繁琐的配置
(3)提供了一系列大型项目通用的非业务性功能。例如:内嵌服务器、安全管理、运行数据监控、运行状况检查和外部化配置等
(4)没有代码生成,也不需要XML配置
(5)避免大量的Maven导入和各种版本冲突


3.Spring Boot核心注解是哪个?主要由哪几个注解组成?

启动类上面的注解是@SpringBootApplication,也是Spring Boot的核心注解,主要组合包含了以下3个注解

核心注解描述
@SpringBootConfiguration组合了@Configuration注解,实现配置文件的功能
@ComponentScanSpring组件扫描
@EnableAutoConfiguration打开自动配置的功能,也可以关闭某个自动配置的选项

4.什么是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,不需要任何强制转换或基于字符串的查找


5.Spring Boot自动配置原理是什么?

注解:@EnableAutoConfiguration、@Configuration、@ConditionalOnClass

自动配置的核心,@EnableAutoConfiguration给容器导入META-INF/spring.factories 里定义的自动配置类。筛选有效的自动配置类。每一个自动配置类结合对应的xxxProperties.java读取配置文件进行自动配置功能


6.Spring Boot配置加载顺序?

(1)properties文件
(2)YAML文件
(3)系统环境变量
(4)命令行参数
(5)等等……


7.什么是YAML?

YAML 是一种人类可读的数据序列化语言。它通常用于配置文件。与属性文件相比,如果我们想要在配置文件中添加复杂的属性,YAML 文件就更加结构化,而且更少混淆。可以看出 YAML 具有分层配置数据


8.YAML配置的优势在哪里 ?

(1)配置有序,在一些特殊的场景下,配置有序很关键
(2)支持数组,数组中的元素可以是基本数据类型也可以是对象
(3)简洁
相比properties配置文件,YAML还有一个缺点,就是不支持@PropertySource注解导入自定义的YAML配置


9.Spring Boot是否可以使用XML配置 ?

Spring Boot 推荐使用Java配置而非XML配置,但是Spring Boot中也可以使用XML配置,通过@ImportResource注解可以引入一个XML配置


10.Spring Boot核心配置文件是什么?bootstrap.properties和application.properties有何区别 ?

单纯做Spring Boot开发,可能不太容易遇到bootstrap.properties配置文件,但是在结合 Spring Cloud时,这个配置就会经常遇到了,特别是在需要加载一些远程配置文件的时侯。

Spring Boot核心的两个配置文件:
(1)bootstrap(. yml或者. properties)
boostrap由父ApplicationContext加载的,比applicaton优先加载,配置在应用程序上下文的引导阶段生效。一般来说在Spring Cloud Config或者Nacos中会用到它。且boostrap里面的属性不能被覆盖

(2)application(. yml或者. properties)
由ApplicatonContext 加载,用于Spring Boot项目的自动化配置


11.什么是Spring Profiles?

Spring Profiles允许用户根据配置文件(dev、test、prod 等)来注册bean。因此,当应用程序在开发中运行时,只有某些bean可以加载,而在PRODUCTION中,某些其他bean可以加载。假设我们的要求是Swagger文档仅适用于QA环境,并且禁用所有其他文档。这可以使用配置文件来完成。Spring Boot 使得使用配置文件非常简单


12.如何在自定义端口上运行 Spring Boot 应用程序?

application.properties中指定端口。server.port = 8090


13.如何实现Spring Boot应用程序的安全性?

为了实现Spring Boot的安全性,使用spring-boot-starter-security 依赖项,并且必须添加安全配置。它只需要很少的代码。配置类将必须扩展WebSecurityConfigurerAdapter并覆盖其方法


14.Spring Security和Shiro各自的优缺点?

由于Spring Boot官方提供了大量的非常方便的开箱即用的Starter ,包括Spring Security的 Starter ,使得在Spring Boot中使用Spring Security变得更加容易,甚至只需要添加一个依赖就可以保护所有的接口,所以,如果是Spring Boot项目,一般选择 Spring Security 。当然这只是一个建议的组合,单纯从技术上来说,无论怎么组合,都是没有问题的

Shiro和Spring Security相比,主要有如下一些特点:

ShiroSpring Security
轻量级的安全管理框架重量级的安全管理框架
概念简单、配置简单概念复杂,配置繁琐
功能简单功能强大

15.Spring Boot中如何解决跨域问题?

跨域可以在前端通过JSONP来解决,但是JSONP只可以发送GET请求,无法发送其他类型的请求,在RESTful风格的应用中,就显得非常鸡肋,因此推荐在后端通过 (CORS,Cross-origin resource sharing)来解决跨域问题

通过实现WebMvcConfigurer接口然后重写addCorsMappings方法解决跨域问题

@Configuration
public class CorsConfig implements WebMvcConfigurer {

    @Override
    public void addCorsMappings(CorsRegistry registry) {
        registry.addMapping("/**")
                .allowedOrigins("*")
                .allowCredentials(true)
                .allowedMethods("GET", "POST", "PUT", "DELETE", "OPTIONS")
                .maxAge(3600);
    }

}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

未禾

您的支持是我最宝贵的财富!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值