溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

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

發(fā)布時(shí)間:2020-03-23 12:50:18 來源:網(wǎng)絡(luò) 閱讀:235 作者:架構(gòu)師追風(fēng) 欄目:編程語言

Spring Boot 面試題

1、什么是 Spring Boot?

2、Spring Boot 有哪些優(yōu)點(diǎn)?

3、什么是 JavaConfig?

4、如何重新加載 Spring Boot 上的更改,而無需重新啟動(dòng)服務(wù)器

5、Spring Boot 中的監(jiān)視器是什么?

6、如何在 Spring Boot 中禁用 Actuator 端點(diǎn)安全性?

7、如何在自定義端口上運(yùn)行 Spring Boot 應(yīng)用程序?

8、什么是 YAML?

9、如何實(shí)現(xiàn) Spring Boot 應(yīng)用程序的安全性?

10、如何集成 Spring Boot 和 ActiveMQ?

11、如何使用 Spring Boot 實(shí)現(xiàn)分頁和排序?

12、什么是 Swagger?你用 Spring Boot 實(shí)現(xiàn)了它嗎?

13、什么是 Spring Profiles?

14、什么是 Spring Batch?

15、什么是 FreeMarker 模板?

16、如何使用 Spring Boot 實(shí)現(xiàn)異常處理?

17、您使用了哪些 starter maven 依賴項(xiàng)?

18、什么是 CSRF 攻ji?

19、什么是 WebSockets?

20、什么是 AOP?

21、什么是 Apache Kafka?

22、我們?nèi)绾伪O(jiān)視所有 Spring Boot 微服務(wù)?

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

1、什么是 Spring Boot?

多年來,隨著新功能的增加,spring 變得越來越復(fù)雜。訪問spring官網(wǎng)頁面,我們就會(huì)看到可以在我們的應(yīng)用程序中使用的所有 Spring 項(xiàng)目的不同功能。如果必須啟動(dòng)一個(gè)新的 Spring 項(xiàng)目,我們必須添加構(gòu)建路徑或添加 Maven 依賴關(guān)系,配置應(yīng)用程序服務(wù)器,添加 spring 配置。因此,開始一個(gè)新的 spring 項(xiàng)目需要很多努力,因?yàn)槲覀儸F(xiàn)在必須從頭開始做所有事情。

Spring Boot 是解決這個(gè)問題的方法。Spring Boot 已經(jīng)建立在現(xiàn)有 spring 框架之上。使用 spring 啟動(dòng),我們避免了之前我們必須做的所有樣板代碼和配置。因此,Spring Boot 可以幫助我們以最少的工作量,更加健壯地使用現(xiàn)有的 Spring功能。

2、Spring Boot 有哪些優(yōu)點(diǎn)?

Spring Boot 的優(yōu)點(diǎn)有:

1、減少開發(fā),測(cè)試時(shí)間和努力。

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

3、避免大量的 Maven 導(dǎo)入和各種版本沖突。

4、提供意見發(fā)展方法。

5、通過提供默認(rèn)值快速開始開發(fā)。

6、沒有單獨(dú)的 Web 服務(wù)器需要。這意味著你不再需要啟動(dòng) Tomcat,Glassfish或其他任何東西。

7、需要更少的配置 因?yàn)闆]有 web.xml 文件。只需添加用@ Configuration 注釋的類,然后添加用@Bean 注釋的方法,Spring 將自動(dòng)加載對(duì)象并像以前一樣對(duì)其進(jìn)行管理。您甚至可以將@Autowired 添加到 bean 方法中,以使 Spring 自動(dòng)裝入需要的依賴關(guān)系中。

8、基于環(huán)境的配置 使用這些屬性,您可以將您正在使用的環(huán)境傳遞到應(yīng)用程序:-Dspring.profiles.active = {enviornment}。在加載主應(yīng)用程序?qū)傩晕募?,Spring 將在(application{environment} .properties)中加載后續(xù)的應(yīng)用程序?qū)傩晕募?/p>

3、什么是 JavaConfig?

Spring JavaConfig 是 Spring 社區(qū)的產(chǎn)品,它提供了配置 Spring IoC 容器的純Java 方法。因此它有助于避免使用 XML 配置。使用 JavaConfig 的優(yōu)點(diǎn)在于:

(1)面向?qū)ο蟮呐渲谩?/span>由于配置被定義為 JavaConfig 中的類,因此用戶可以充分利用 Java 中的面向?qū)ο蠊δ?。一個(gè)配置類可以繼承另一個(gè),重寫它的@Bean 方法等。

(2)減少或消除 XML 配置。基于依賴注入原則的外化配置的好處已被證明。但是,許多開發(fā)人員不希望在 XML 和 Java 之間來回切換。JavaConfig 為開發(fā)人員提供了一種純 Java 方法來配置與 XML 配置概念相似的 Spring 容器。從技術(shù)角度來講,只使用 JavaConfig 配置類來配置容器是可行的,但實(shí)際上很多人認(rèn)為將JavaConfig 與 XML 混合匹配是理想的。

(3)類型安全和重構(gòu)友好。JavaConfig 提供了一種類型安全的方法來配置 Spring容器。由于 Java 5.0 對(duì)泛型的支持,現(xiàn)在可以按類型而不是按名稱檢索 bean,不需要任何強(qiáng)制轉(zhuǎn)換或基于字符串的查找。

4、如何重新加載 Spring Boot 上的更改,而無需重新啟動(dòng)服務(wù)器?

這可以使用 DEV 工具來實(shí)現(xiàn)。通過這種依賴關(guān)系,您可以節(jié)省任何更改,嵌入式tomcat 將重新啟動(dòng)。Spring Boot 有一個(gè)開發(fā)工具(DevTools)模塊,它有助于提高開發(fā)人員的生產(chǎn)力。Java 開發(fā)人員面臨的一個(gè)主要挑戰(zhàn)是將文件更改自動(dòng)部署到服務(wù)器并自動(dòng)重啟服務(wù)器。開發(fā)人員可以重新加載 Spring Boot 上的更改,而無需重新啟動(dòng)服務(wù)器。這將消除每次手動(dòng)部署更改的需要。Spring Boot 在發(fā)布它的第一個(gè)版本時(shí)沒有這個(gè)功能。這是開發(fā)人員最需要的功能。DevTools 模塊完全滿足開發(fā)人員的需求。該模塊將在生產(chǎn)環(huán)境中被禁用。它還提供 H2 數(shù)據(jù)庫控制臺(tái)以更好地測(cè)試應(yīng)用程序。

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

5、Spring Boot 中的監(jiān)視器是什么?

Spring boot actuator 是 spring 啟動(dòng)框架中的重要功能之一。Spring boot 監(jiān)視器可幫助您訪問生產(chǎn)環(huán)境中正在運(yùn)行的應(yīng)用程序的當(dāng)前狀態(tài)。有幾個(gè)指標(biāo)必須在生產(chǎn)環(huán)境中進(jìn)行檢查和監(jiān)控。即使一些外部應(yīng)用程序可能正在使用這些服務(wù)來向相關(guān)人員觸發(fā)警報(bào)消息。監(jiān)視器模塊公開了一組可直接作為 HTTP URL 訪問的REST 端點(diǎn)來檢查狀態(tài)。

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

6、如何在 Spring Boot 中禁用 Actuator 端點(diǎn)安全性?

默認(rèn)情況下,所有敏感的 HTTP 端點(diǎn)都是安全的,只有具有 ACTUATOR 角色的用戶才能訪問它們。安全性是使用標(biāo)準(zhǔn)的 HttpServletRequest.isUserInRole 方法實(shí)施的。 我們可以使用來禁用安全性。只有在執(zhí)行機(jī)構(gòu)端點(diǎn)在防火墻后訪問時(shí),才建議禁用安全性。

7、如何在自定義端口上運(yùn)行 Spring Boot 應(yīng)用程序?

為了在自定義端口上運(yùn)行 Spring Boot 應(yīng)用程序,您可以在application.properties 中指定端口。server.port = 8090

8、什么是 YAML?

YAML 是一種人類可讀的數(shù)據(jù)序列化語言。它通常用于配置文件。與屬性文件相比,如果我們想要在配置文件中添加復(fù)雜的屬性,YAML 文件就更加結(jié)構(gòu)化,而且更少混淆??梢钥闯?YAML 具有分層配置數(shù)據(jù)。

9、如何實(shí)現(xiàn) Spring Boot 應(yīng)用程序的安全性?

為了實(shí)現(xiàn) Spring Boot 的安全性,我們使用 spring-boot-starter-security 依賴項(xiàng),并且必須添加安全配置。它只需要很少的代碼。配置類將必須擴(kuò)展WebSecurityConfigurerAdapter 并覆蓋其方法。

10、如何集成 Spring Boot 和 ActiveMQ?

對(duì)于集成 Spring Boot 和 ActiveMQ,我們使用依賴關(guān)系。 它只需要很少的配置,并且不需要樣板代碼。

11、如何使用 Spring Boot 實(shí)現(xiàn)分頁和排序?

使用 Spring Boot 實(shí)現(xiàn)分頁非常簡單。使用 Spring Data-JPA 可以實(shí)現(xiàn)將可分頁的傳遞給存儲(chǔ)庫方法。

12、什么是 Swagger?你用 Spring Boot 實(shí)現(xiàn)了它嗎?

Swagger 廣泛用于可視化 API,使用 Swagger UI 為前端開發(fā)人員提供在線沙箱。Swagger 是用于生成 RESTful Web 服務(wù)的可視化表示的工具,規(guī)范和完整框架實(shí)現(xiàn)。它使文檔能夠以與服務(wù)器相同的速度更新。當(dāng)通過 Swagger 正確定義時(shí),消費(fèi)者可以使用最少量的實(shí)現(xiàn)邏輯來理解遠(yuǎn)程服務(wù)并與其進(jìn)行交互。因此,Swagger消除了調(diào)用服務(wù)時(shí)的猜測(cè)。

13、什么是 Spring Profiles?

Spring Profiles 允許用戶根據(jù)配置文件(dev,test,prod 等)來注冊(cè) bean。因此,當(dāng)應(yīng)用程序在開發(fā)中運(yùn)行時(shí),只有某些 bean 可以加載,而在 PRODUCTION中,某些其他 bean 可以加載。假設(shè)我們的要求是 Swagger 文檔僅適用于 QA 環(huán)境,并且禁用所有其他文檔。這可以使用配置文件來完成。Spring Boot 使得使用配置文件非常簡單。

14、什么是 Spring Batch?

Spring Boot Batch 提供可重用的函數(shù),這些函數(shù)在處理大量記錄時(shí)非常重要,包括日志/跟蹤,事務(wù)管理,作業(yè)處理統(tǒng)計(jì)信息,作業(yè)重新啟動(dòng),跳過和資源管理。它還提供了更先進(jìn)的技術(shù)服務(wù)和功能,通過優(yōu)化和分區(qū)技術(shù),可以實(shí)現(xiàn)極高批量和高性能批處理作業(yè)。簡單以及復(fù)雜的大批量批處理作業(yè)可以高度可擴(kuò)展的方式利用框架處理重要大量的信息。

15、什么是 FreeMarker 模板?

FreeMarker 是一個(gè)基于 Java 的模板引擎,最初專注于使用 MVC 軟件架構(gòu)進(jìn)行動(dòng)態(tài)網(wǎng)頁生成。使用 Freemarker 的主要優(yōu)點(diǎn)是表示層和業(yè)務(wù)層的完全分離。程序員可以處理應(yīng)用程序代碼,而設(shè)計(jì)人員可以處理 html 頁面設(shè)計(jì)。最后使用freemarker 可以將這些結(jié)合起來,給出最終的輸出頁面。

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

16、如何使用 Spring Boot 實(shí)現(xiàn)異常處理?

Spring 提供了一種使用 ControllerAdvice 處理異常的非常有用的方法。 我們通過實(shí)現(xiàn)一個(gè) ControlerAdvice 類,來處理控制器類拋出的所有異常。

17、您使用了哪些 starter maven 依賴項(xiàng)?

使用了下面的一些依賴項(xiàng)

spring-boot-starter-activemq

spring-boot-starter-security

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

18、什么是 CSRF ***?

CSRF 代表跨站請(qǐng)求偽造。這是一種***,迫使最終用戶在當(dāng)前通過身份驗(yàn)證的Web 應(yīng)用程序上執(zhí)行不需要的操作。CSRF ***專門針對(duì)狀態(tài)改變請(qǐng)求,而不是數(shù)據(jù)竊取,因?yàn)?**者無法查看對(duì)偽造請(qǐng)求的響應(yīng)。

19、什么是 WebSockets?

WebSocket 是一種計(jì)算機(jī)通信協(xié)議,通過單個(gè) TCP 連接提供全雙工通信信道。

1、WebSocket 是雙向的 -使用 WebSocket 客戶端或服務(wù)器可以發(fā)起消息發(fā)送。

2、WebSocket 是全雙工的 -客戶端和服務(wù)器通信是相互獨(dú)立的。

3、單個(gè) TCP 連接 -初始連接使用 HTTP,然后將此連接升級(jí)到基于套接字的連接。然后這個(gè)單一連接用于所有未來的通信

4、Light -與 http 相比,WebSocket 消息數(shù)據(jù)交換要輕得多。

20、什么是 AOP?

在軟件開發(fā)過程中,跨越應(yīng)用程序多個(gè)點(diǎn)的功能稱為交叉問題。這些交叉問題與應(yīng)用程序的主要業(yè)務(wù)邏輯不同。因此,將這些橫切關(guān)注與業(yè)務(wù)邏輯分開是面向方面編程(AOP)的地方。

21、什么是 Apache Kafka?

Apache Kafka 是一個(gè)分布式發(fā)布 - 訂閱消息系統(tǒng)。它是一個(gè)可擴(kuò)展的,容錯(cuò)的發(fā)布 - 訂閱消息系統(tǒng),它使我們能夠構(gòu)建分布式應(yīng)用程序。這是一個(gè) Apache 頂級(jí)項(xiàng)目。Kafka 適合離線和在線消息消費(fèi)。

22、我們?nèi)绾伪O(jiān)視所有 Spring Boot 微服務(wù)?

Spring Boot 提供監(jiān)視器端點(diǎn)以監(jiān)控各個(gè)微服務(wù)的度量。這些端點(diǎn)對(duì)于獲取有關(guān)應(yīng)用程序的信息(如它們是否已啟動(dòng))以及它們的組件(如數(shù)據(jù)庫等)是否正常運(yùn)行很有幫助。但是,使用監(jiān)視器的一個(gè)主要缺點(diǎn)或困難是,我們必須單獨(dú)打開應(yīng)用程序的知識(shí)點(diǎn)以了解其狀態(tài)或健康狀況。想象一下涉及 50 個(gè)應(yīng)用程序的微服務(wù),管理員將不得不擊中所有 50 個(gè)應(yīng)用程序的執(zhí)行終端。為了幫助我們處理這種情況,我們將使用位于的開源項(xiàng)目。 它建立在 Spring Boot Actuator 之上,它提供了一個(gè) Web UI,使我們能夠可視化多個(gè)應(yīng)用程序的度量。

耗時(shí)1個(gè)月時(shí)間,整理了1000道2019年多家公司java面試題400多頁pdf文檔,歡迎大家關(guān)注我的公種浩【程序員追風(fēng)】,文章都會(huì)在里面更新,整理的資料也會(huì)放在里面

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

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


針對(duì)于上面的面試問到的知識(shí)點(diǎn)我總結(jié)出了互聯(lián)網(wǎng)公司Java程序員面試涉及到的絕大部分面試題及答案做成了文檔和架構(gòu)資料分享給大家,家希望能幫助到您面試前的復(fù)習(xí)且找到一個(gè)好的工作,也節(jié)省大家在網(wǎng)上搜索資料的時(shí)間來學(xué)習(xí)。

最后

歡迎大家一起交流,整理資料不易,喜歡文章記得點(diǎn)個(gè)贊喲,感謝支持!


向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI