天天看點

2020年Spring Boot面試都問了什麼?快看看這22道面試題!

Spring Boot 面試題

1、什麼是 Spring Boot?

2、Spring Boot 有哪些優點?

3、什麼是 JavaConfig?

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

5、Spring Boot 中的螢幕是什麼?

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

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

8、什麼是 YAML?

9、如何實作 Spring Boot 應用程式的安全性?

10、如何內建 Spring Boot 和 ActiveMQ?

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

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

13、什麼是 Spring Profiles?

14、什麼是 Spring Batch?

15、什麼是 FreeMarker 模闆?

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

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

18、什麼是 CSRF 攻擊?

19、什麼是 WebSockets?

20、什麼是 AOP?

21、什麼是 Apache Kafka?

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

2020年Spring Boot面試都問了什麼?快看看這22道面試題!

多年來,随着新功能的增加,spring 變得越來越複雜。通路spring官網頁面,我們就會看到可以在我們的應用程式中使用的所有 Spring 項目的不同功能。如果必須啟動一個新的 Spring 項目,我們必須添加建構路徑或添加 Maven 依賴關系,配置應用程式伺服器,添加 spring 配置。是以,開始一個新的 spring 項目需要很多努力,因為我們現在必須從頭開始做所有事情。

Spring Boot 是解決這個問題的方法。Spring Boot 已經建立在現有 spring 架構之上。使用 spring 啟動,我們避免了之前我們必須做的所有樣闆代碼和配置。是以,Spring Boot 可以幫助我們以最少的工作量,更加健壯地使用現有的 Spring功能。

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)中加載後續的應用程式屬性檔案。

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,不需要任何強制轉換或基于字元串的查找。

這可以使用 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>複制代碼      

Spring boot actuator 是 spring 啟動架構中的重要功能之一。Spring boot 螢幕可幫助您通路生産環境中正在運作的應用程式的目前狀态。有幾個名額必須在生産環境中進行檢查和監控。即使一些外部應用程式可能正在使用這些服務來向相關人員觸發警報消息。螢幕子產品公開了一組可直接作為 HTTP URL 通路的REST 端點來檢查狀态。

2020年Spring Boot面試都問了什麼?快看看這22道面試題!

預設情況下,所有敏感的 HTTP 端點都是安全的,隻有具有 ACTUATOR 角色的使用者才能通路它們。安全性是使用标準的 HttpServletRequest.isUserInRole 方法實施的。 我們可以使用來禁用安全性。隻有在執行機構端點在防火牆後通路時,才建議禁用安全性。

為了在自定義端口上運作 Spring Boot 應用程式,您可以在application.properties 中指定端口。server.port = 8090

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

為了實作 Spring Boot 的安全性,我們使用 spring-boot-starter-security 依賴項,并且必須添加安全配置。它隻需要很少的代碼。配置類将必須擴充WebSecurityConfigurerAdapter 并覆寫其方法。

對于內建 Spring Boot 和 ActiveMQ,我們使用依賴關系。 它隻需要很少的配置,并且不需要樣闆代碼。

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

Swagger 廣泛用于可視化 API,使用 Swagger UI 為前端開發人員提供線上沙箱。Swagger 是用于生成 RESTful Web 服務的可視化表示的工具,規範和完整架構實作。它使文檔能夠以與伺服器相同的速度更新。當通過 Swagger 正确定義時,消費者可以使用最少量的實作邏輯來了解遠端服務并與其進行互動。是以,Swagger消除了調用服務時的猜測。

Spring Profiles 允許使用者根據配置檔案(dev,test,prod 等)來注冊 bean。是以,當應用程式在開發中運作時,隻有某些 bean 可以加載,而在 PRODUCTION中,某些其他 bean 可以加載。假設我們的要求是 Swagger 文檔僅适用于 QA 環境,并且禁用所有其他文檔。這可以使用配置檔案來完成。Spring Boot 使得使用配置檔案非常簡單。

Spring Boot Batch 提供可重用的函數,這些函數在處理大量記錄時非常重要,包括日志/跟蹤,事務管理,作業處理統計資訊,作業重新啟動,跳過和資源管理。它還提供了更先進的技術服務和功能,通過優化和分區技術,可以實作極高批量和高性能批處理作業。簡單以及複雜的大批量批處理作業可以高度可擴充的方式利用架構處理重要大量的資訊。

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

2020年Spring Boot面試都問了什麼?快看看這22道面試題!

Spring 提供了一種使用 ControllerAdvice 處理異常的非常有用的方法。 我們通過實作一個 ControlerAdvice 類,來處理控制器類抛出的所有異常。

使用了下面的一些依賴項

spring-boot-starter-activemq

spring-boot-starter-security

這有助于增加更少的依賴關系,并減少版本的沖突。

CSRF 代表跨站請求僞造。這是一種攻擊,迫使最終使用者在目前通過身份驗證的Web 應用程式上執行不需要的操作。CSRF 攻擊專門針對狀态改變請求,而不是資料竊取,因為攻擊者無法檢視對僞造請求的響應。

WebSocket 是一種計算機通信協定,通過單個 TCP 連接配接提供全雙工通信信道。

1、WebSocket 是雙向的 -使用 WebSocket 用戶端或伺服器可以發起消息發送。

2、WebSocket 是全雙工的 -用戶端和伺服器通信是互相獨立的。

3、單個 TCP 連接配接 -初始連接配接使用 HTTP,然後将此連接配接更新到基于套接字的連接配接。然後這個單一連接配接用于所有未來的通信

4、Light -與 http 相比,WebSocket 消息資料交換要輕得多。

在軟體開發過程中,跨越應用程式多個點的功能稱為交叉問題。這些交叉問題與應用程式的主要業務邏輯不同。是以,将這些橫切關注與業務邏輯分開是面向方面程式設計(AOP)的地方。

Apache Kafka 是一個分布式釋出 - 訂閱消息系統。它是一個可擴充的,容錯的釋出 - 訂閱消息系統,它使我們能夠建構分布式應用程式。這是一個 Apache 頂級項目。Kafka 适合離線和線上消息消費。