java Spring Boot面試題附pdf答案(最全版本持續更新)

前言

涵蓋各大公司會問到的面試點,同時隨着版本的升級,可能也會有一些面試題更新,也會同步保持更新,因爲篇幅原因(其實是我懶,哈哈)所以列了一部分答案,所有的答案見下文,總共485頁合計20個技術點,文末自取pdf.

 

1、什麼是 Spring Boot?

 

2、Spring Boot 有哪些優點?

 

Spring Boot 的優點有:

 

1、減少開發,測試時間和努力。

 

2、使用 JavaConfig 有助於避免使用 XML。

 

3、避免大量的 Maven 導入和各種版本衝突。

 

4、提供意見發展方法。

 

5、通過提供默認值快速開始開發。

 

6、沒有單獨的 Web 服務器需要。這意味着你不再需要啓動 Tomcat,Glassfish或其他任何東西。

 

7、需要更少的配置 因爲沒有 web.xml 文件。只需添加用@ Configuration 註釋的類,然後添加用@Bean 註釋的方法,Spring 將自動加載對象並像以前一樣對其進行管理。您甚至可以將@Autowired 添加到 bean 方法中,以使 Spring 自動裝入需要的依賴關係中。

 

8、基於環境的配置 使用這些屬性,您可以將您正在使用的環境傳遞到應用程序:-Dspring.profiles.active = {enviornment}。在加載主應用程序屬性文件後,Spring 將在(application{environment} .properties)中加載後續的應用程序屬性文件。

 

3、什麼是 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,不需要任何強制轉換或基於字符串的查找。

 

4、如何重新加載 Spring Boot 上的更改,而無需重新啓動服務器?

 

這可以使用 DEV 工具來實現。通過這種依賴關係,您可以節省任何更改,嵌入式tomcat 將重新啓動。Spring Boot 有一個開發工具(DevTools)模塊,它有助於提高開發人員的生產力。

 

Java 開發人員面臨的一個主要挑戰是將文件更改自動部署到服務器並自動重啓服務器。

 

開發人員可以重新加載 Spring Boot 上的更改,而無需重新啓動服務器。這將消除每次手動部署更改的需要。

 

Spring Boot 在發佈它的第一個版本時沒有這個功能。這是開發人員最需要的功能。

 

DevTools 模塊完全滿足開發人員的需求。該模塊將在生產環境中被禁用。

 

它還提供 H2 數據庫控制檯以更好地測試應用程序.

<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>

5、Spring Boot 中的監視器是什麼?

 

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

 

6、如何在 Spring Boot 中禁用 Actuator 端點安全性?

 

默認情況下,所有敏感的 HTTP 端點都是安全的,只有具有 ACTUATOR 角色的用戶才能訪問它們。安全性是使用標準的 HttpServletRequest.isUserInRole 方法實施的。 我們可以使用來禁用安全性。只有在執行機構端點在防火牆後訪問時,才建議禁用安全性。

 

7、如何在自定義端口上運行 Spring Boot 應用程序?

 

爲了在自定義端口上運行 Spring Boot 應用程序,您可以在application.properties 中指定端口。

server.port = 8090

8、什麼是 YAML?

 

YAML 是一種人類可讀的數據序列化語言。它通常用於配置文件。與屬性文件相比,如果我們想要在配置文件中添加複雜的屬性,YAML 文件就更加結構化,而且更少混淆。可以看出 YAML 具有分層配置數據。

 

9、如何實現 Spring Boot 應用程序的安全性?

 

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

 

10、如何集成 Spring Boot 和 ActiveMQ?

 

對於集成 Spring Boot 和 ActiveMQ,我們使用依賴關係。 它只需要很少的配置,並且不需要樣板代碼。

 

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

 

使用 Spring Boot 實現分頁非常簡單。使用 Spring Data-JPA 可以實現將可分頁的傳遞給存儲庫方法。

 

12、什麼是 Swagger?你用 Spring Boot 實現了它嗎?

 

Swagger 廣泛用於可視化 API,使用 Swagger UI 爲前端開發人員提供在線沙箱。

 

Swagger 是用於生成 RESTful Web 服務的可視化表示的工具,規範和完整框架實現。它使文檔能夠以與服務器相同的速度更新。當通過 Swagger 正確定義時,消費者可以使用最少量的實現邏輯來理解遠程服務並與其進行交互。因此,Swagger消除了調用服務時的猜測。

 

13、什麼是 Spring Profiles?

 

Spring Profiles 允許用戶根據配置文件(dev,test,prod 等)來註冊 bean。因此,當應用程序在開發中運行時,只有某些 bean 可以加載,而在 PRODUCTION中,某些其他 bean 可以加載。假設我們的要求是 Swagger 文檔僅適用於 QA 環境,並且禁用所有其他文檔。

 

這可以使用配置文件來完成。Spring Boot 使得使用配置文件非常簡單。

 

14、什麼是 Spring Batch?

 

Spring Boot Batch 提供可重用的函數,這些函數在處理大量記錄時非常重要,包括日誌/跟蹤,事務管理,作業處理統計信息,作業重新啓動,跳過和資源管理。它還提供了更先進的技術服務和功能,通過優化和分區技術,可以實現極高批量和高性能批處理作業。簡單以及

 

複雜的大批量批處理作業可以高度可擴展的方式利用框架處理重要大量的信息。

 

15、什麼是 FreeMarker 模板?

 

FreeMarker 是一個基於 Java 的模板引擎,最初專注於使用 MVC 軟件架構進行動態網頁生成。使用 Freemarker 的主要優點是表示層和業務層的完全分離。程序員可以處理應用程序代碼,而設計人員可以處理 html 頁面設計。最後使用freemarker 可以將這些結合起來,給出最終的輸出頁面.

 

16、如何使用 Spring Boot 實現異常處理?

 

17、您使用了哪些 starter maven 依賴項?

 

18、什麼是 CSRF 攻擊?

 

19、什麼是 WebSockets?

 

20、什麼是 AOP?

 

21、什麼是 Apache Kafka?

 

22、我們如何監視所有 Spring Boot 微服務?

 收集了各方面的,當前公司的,還有自己收集總結的,下面的圖片截取的有pdf,有如果有需要的自取.

各大公司面試題集合:

獲取方式後臺私信博主【資料】即可

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章