本文為大家分享了10道springboot常見面試題,供大家參考,具體內容如下
1.什么是spring boot?
多年來,隨著新功能的增加,spring變得越來越復雜。只需訪問https://spring.io/projects頁面,我們就會看到可以在我們的應用程序中使用的所有spring項目的不同功能。
如果必須啟動一個新的spring項目,我們必須添加構建路徑或添加maven依賴關系,配置應用程序服務器,添加spring配置。
因此,開始一個新的spring項目需要很多努力,因為我們現在必須從頭開始做所有事情。
spring boot是解決這個問題的方法。spring boot已經建立在現有spring框架之上。使用spring啟動,我們避免了之前我們必須做的所有樣板代碼和配置。
因此,spring boot可以幫助我們以最少的工作量,更加健壯地使用現有的spring功能。
2.spring boot有哪些優點?
- 減少開發,測試時間和努力。
- 使用javaconfig有助于避免使用xml。
- 避免大量的maven導入和各種版本沖突。
- 提供意見發展方法。
- 通過提供默認值快速開始開發。
- 沒有單獨的web服務器需要。這意味著你不再需要啟動tomcat,glassfish或其他任何東西。
- 需要更少的配置 因為沒有web.xml文件。只需添加用@ configuration注釋的類,然后添加用@bean注釋的方法,spring將自動加載對象并像以前一樣對其進行管理。您甚至可以將@autowired添加到bean方法中,以使spring自動裝入需要的依賴關系中。
- 基于環境的配置 使用這些屬性,您可以將您正在使用的環境傳遞到應用程序:-dspring.profiles.active = {enviornment}。在加載主應用程序屬性文件后,spring將在(application{environment} .properties)中加載后續的應用程序屬性文件。
3.什么是javaconfig?
spring javaconfig是spring社區的產品,它提供了配置spring ioc容器的純java方法。因此它有助于避免使用xml配置。使用javaconfig的優點在于:
面向對象的配置。由于配置被定義為javaconfig中的類,因此用戶可以充分利用java中的面向對象功能。一個配置類可以繼承另一個,重寫它的@bean方法等。
減少或消除xml配置。基于依賴注入原則的外化配置的好處已被證明。但是,許多開發人員不希望在xml和java之間來回切換。
javaconfig為開發人員提供了一種純java方法來配置與xml配置概念相似的spring容器。
從技術角度來講,只使用javaconfig配置類來配置容器是可行的,但實際上很多人認為將javaconfig與xml混合匹配是理想的。
類型安全和重構友好。javaconfig提供了一種類型安全的方法來配置spring容器。由于java 5.0對泛型的支持,現在可以按類型而不是按名稱檢索bean,不需要任何強制轉換或基于字符串的查找。
4.如何重新加載spring boot上的更改,而無需重新啟動服務器?
這可以使用dev工具來實現。通過這種依賴關系,您可以節省任何更改,嵌入式tomcat將重新啟動。
spring boot有一個開發工具(devtools)模塊,它有助于提高開發人員的生產力。java開發人員面臨的一個主要挑戰是將文件更改自動部署到服務器并自動重啟服務器。
開發人員可以重新加載spring boot上的更改,而無需重新啟動服務器。這將消除每次手動部署更改的需要。spring boot在發布它的第一個版本時沒有這個功能。
這是開發人員最需要的功能。devtools模塊完全滿足開發人員的需求。該模塊將在生產環境中被禁用。它還提供h2數據庫控制臺以更好地測試應用程序。
1
2
3
4
5
|
<dependency> <groupid>org.springframework.boot</groupid> <artifactid>spring-boot-devtools</artifactid> <optional> true </optional> </dependency> |
5.spring boot中的監視器是什么?
spring boot actuator是spring啟動框架中的重要功能之一。spring boot監視器可幫助您訪問生產環境中正在運行的應用程序的當前狀態。
有幾個指標必須在生產環境中進行檢查和監控。即使一些外部應用程序可能正在使用這些服務來向相關人員觸發警報消息。監視器模塊公開了一組可直接作為http url訪問的rest端點來檢查狀態。
6.如何在spring boot中禁用actuator端點安全性?
默認情況下,所有敏感的http端點都是安全的,只有具有actuator角色的用戶才能訪問它們。
安全性是使用標準的httpservletrequest.isuserinrole方法實施的。 我們可以使用management.security.enabled = false 來禁用安全性。只有在執行機構端點在防火墻后訪問時,才建議禁用安全性。
如何在自定義端口上運行spring boot應用程序?
為了在自定義端口上運行spring boot應用程序,您可以在application.properties中指定端口。
server.port = 8090
7.什么是yaml?
yaml是一種人類可讀的數據序列化語言。它通常用于配置文件。
與屬性文件相比,如果我們想要在配置文件中添加復雜的屬性,yaml文件就更加結構化,而且更少混淆??梢钥闯鰕aml具有分層配置數據。
8.如何實現spring boot應用程序的安全性?
為了實現spring boot的安全性,我們使用 spring-boot-starter-security依賴項,并且必須添加安全配置。它只需要很少的代碼。配置類將必須擴展websecurityconfigureradapter并覆蓋其方法。
9.如何集成spring boot和activemq?
對于集成spring boot和activemq,我們使用spring-boot-starter-activemq
依賴關系。 它只需要很少的配置,并且不需要樣板代碼。
10.如何使用spring boot實現分頁和排序?
使用spring boot實現分頁非常簡單。使用spring data-jpa可以實現將可分頁的org.springframework.data.domain.pageable傳遞給存儲庫方法。
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。