20 道 Spring Boot 面試題你須要瞭解下

一、什麼是 Spring Boot?

Spring Boot 是 Spring 開源組織下的子項目,是 Spring 組件一站式解決方案,主要是簡化了使用 Spring 的難度,簡省了繁重的配置,提供了各類啓動器,開發者能快速上手。前端

二、Spring Boot有哪些優勢?

減小開發,測試時間和努力。java

使用JavaConfig有助於避免使用XML。web

避免大量的Maven導入和各類版本衝突。spring

提供意見發展方法。編程

經過提供默認值快速開始開發。bootstrap

沒有單獨的Web服務器須要。這意味着你再也不須要啓動Tomcat,Glassfish或其餘任何東西。安全

須要更少的配置 由於沒有web.xml文件。只需添加用@ Configuration註釋的類,而後添加用@Bean註釋的方法,Spring將自動加載對象並像之前同樣對其進行管理。您甚至能夠將@Autowired添加到bean方法中,以使Spring自動裝入須要的依賴關係中。基於環境的配置 使用這些屬性,您能夠將您正在使用的環境傳遞到應用程序:-Dspring.profiles.active = {enviornment}。在加載主應用程序屬性文件後,Spring將在(application{environment} .properties)中加載後續的應用程序屬性文件。
bash

三、Spring Boot 的核心配置文件有哪幾個?它們的區別是什麼?

Spring Boot 的核心配置文件是 application 和 bootstrap 配置文件。服務器

application 配置文件這個容易理解,主要用於 Spring Boot 項目的自動化配置。app

bootstrap 配置文件有如下幾個應用場景。

使用 Spring Cloud Config 配置中心時,這時須要在 bootstrap 配置文件中添加鏈接到配置中心的配置屬性來加載外部配置中心的配置信息; 一些固定的不能被覆蓋的屬性;一些加密/解密的場景

四、Spring Boot 的配置文件有哪幾種格式?它們有什麼區別?

.properties 和 .yml,它們的區別主要是書寫格式不一樣。

1 , properties

app.user.name = javastack

複製代碼

2, yml

app:
  user:
    name: javastack
複製代碼

五、Spring Boot 的核心註解是哪一個?它主要由哪幾個註解組成的?

啓動類上面的註解是@SpringBootApplication,它也是 Spring Boot 的核心註解 主要組合包含了如下 3 個註解:

@SpringBootConfiguration:組合了 @Configuration 註解,實現配置文件的功能。
@EnableAutoConfiguration:打開自動配置的功能,也能夠關閉某個自動配置的選項,如關閉數據源自動配置功能: @SpringBootApplication(exclude = { DataSourceAutoConfiguration.class })。
@ComponentScan:Spring組件掃描。

六、開啓 Spring Boot 特性有哪幾種方式?

1)繼承spring-boot-starter-parent項目

2)導入spring-boot-dependencies項目依賴

七、Spring Boot 須要獨立的容器運行嗎?

能夠不須要,內置了 Tomcat/ Jetty 等容器。

八、運行 Spring Boot 有哪幾種方式?

1)打包用命令或者放到容器中運行

2)用 Maven/ Gradle 插件運行

3)直接執行 main 方法運行

九、Spring Boot 自動配置原理是什麼?

註解 @EnableAutoConfiguration, @Configuration, @ConditionalOnClass 就是自動配置的核心,首先它得是一個配置文件,其次根據類路徑下是否有這個類去自動配置。

十、Spring Boot 2.X 有什麼新特性?與 1.X 有什麼區別?

配置變動

JDK 版本升級

第三方類庫升級

響應式 Spring 編程支持

HTTP/2 支持

配置屬性綁定

更多改進與增強…

11 , 如何使用Spring Boot實現分頁和排序?

使用Spring Boot實現分頁很是簡單。使用Spring Data-JPA能夠實現將可分頁的org.springframework.data.domain.Pageable傳遞給存儲庫方法。

12,如何實現Spring Boot應用程序的安全性?

爲了實現Spring Boot的安全性,咱們使用 spring-boot-starter-security依賴項,而且必須添加安全配置。它只須要不多的代碼。配置類將必須擴展WebSecurityConfigurerAdapter並覆蓋其方法。

13,如何集成Spring Boot和ActiveMQ?

對於集成Spring Boot和ActiveMQ,咱們使用spring-boot-starter-activemq 依賴關係。 它只須要不多的配置,而且不須要樣板代碼。

1四、什麼是YAML?

YAML是一種人類可讀的數據序列化語言。它一般用於配置文件。 與屬性文件相比,若是咱們想要在配置文件中添加複雜的屬性,YAML文件就更加結構化,並且更少混淆。能夠看出YAML具備分層配置數據。

15,Spring Boot中的監視器是什麼?

Spring boot actuator是spring啓動框架中的重要功能之一。Spring boot監視器可幫助您訪問生產環境中正在運行的應用程序的當前狀態。有幾個指標必須在生產環境中進行檢查和監控。即便一些外部應用程序可能正在使用這些服務來向相關人員觸發警報消息。監視器模塊公開了一組可直接做爲HTTP URL訪問的REST端點來檢查狀態。

16 ,什麼是Swagger?你用Spring Boot實現了它嗎?

Swagger普遍用於可視化API,使用Swagger UI爲前端開發人員提供在線沙箱。Swagger是用於生成RESTful Web服務的可視化表示的工具,規範和完整框架實現。它使文檔可以以與服務器相同的速度更新。當經過Swagger正肯定義時,消費者可使用最少許的實現邏輯來理解遠程服務並與其進行交互。所以,Swagger消除了調用服務時的猜想。

17,如何使用Spring Boot實現異常處理?

Spring提供了一種使用ControllerAdvice處理異常的很是有用的方法。 咱們經過實現一個ControlerAdvice類,來處理控制器類拋出的全部異常。

18,RequestMapping 和 GetMapping 的不一樣之處在哪裏?

RequestMapping 具備類屬性的,能夠進行 GET,POST,PUT 或者其它的註釋中具備的請求方法。

GetMapping 是 GET 請求方法中的一個特例。它只是 ResquestMapping 的一個延伸,目的是爲了提升清晰度。

1九、Spring Boot 能夠兼容老 Spring 項目嗎,如何作?

能夠兼容,使用 @ImportResource 註解導入老 Spring 項目配置文件。

20、保護 Spring Boot 應用有哪些方法?

在生產中使用HTTPS 使用Snyk檢查你的依賴關係 升級到最新版本 啓用CSRF保護 使用內容安全策略防止XSS攻擊

相關文章
相關標籤/搜索