什麼是 Spring Boot?
多年來,随着新功能的增加,spring 變得越來越複雜。隻需通路 https://spring.io/projects 頁面,我們就會看到可以在我們的應用程式中使用的所有 Spring 項目的不同功能。
如果必須啟動一個新的 Spring 項目,我們必須添加建構路徑或添加 Maven 依賴關系,配置應用程式伺服器,添加 spring 配置。
是以,開始一個新的 spring 項目需要很多努力,因為我們現在必須從頭開始做所有事情。
Spring Boot 是解決這個問題的方法。Spring Boot 已經建立在現有 spring 架構之上。
使用spring 啟動,我們避免了之前我們必須做的所有樣闆代碼和配置。是以,Spring Boot 可以幫助我們以最少的工作量,更加健壯地使用現有的 Spring 功能。
Spring Boot 有哪些優點?
Spring Boot 的優點有:
減少開發,測試時間和努力。
使用 JavaConfig 有助于避免使用 XML。
避免大量的 Maven 導入和各種版本沖突。
提供意見發展方法。
通過提供預設值快速開始開發。
沒有單獨的 Web 伺服器需要。這意味着你不再需要啟動 Tomcat,Glassfish 或其他任何東西。
需要更少的配置 因為沒有 web.xml 檔案。隻需添加用@ Configuration 注釋的類,然後添加用@Bean 注釋的方法,Spring 将自動加載對象并像以前一樣對其進行管理。您甚至可以将@Autowired 添加到 bean 方法中,以使 Spring 自動裝入需要的依賴關系中。
基于環境的配置 使用這些屬性,您可以将您正在使用的環境傳遞到應用程式:-
Dspring.profiles.active = {enviornment}。在加載主應用程式屬性檔案後,Spring 将在(application{environment} .properties)中加載後續的應用程式屬性檔案。
什麼是 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,不需要任何強制轉換或
基于字元串的查找。
如何重新加載 Spring Boot 上的更改,而無需重新啟動伺服器?
這可以使用 DEV 工具來實作。通過這種依賴關系,您可以節省任何更改,嵌入式 tomcat
将重新啟動。Spring Boot 有一個開發工具(DevTools)子產品,它有助于提高開發人員的生
産力。Java 開發人員面臨的一個主要挑戰是将檔案更改自動部署到伺服器并自動重新開機服務
器。開發人員可以重新加載 Spring Boot 上的更改,而無需重新啟動伺服器。這将消除每次
手動部署更改的需要。Spring Boot 在釋出它的第一個版本時沒有這個功能。這是開發人員
最需要的功能。DevTools 子產品完全滿足開發人員的需求。該子產品将在生産環境中被禁用。
它還提供 H2 資料庫控制台以更好地測試應用程式。
org.springframework.boot spring-boot-devtools true
Spring Boot 中的螢幕是什麼?
Spring boot actuator 是 spring 啟動架構中的重要功能之一。Spring boot 螢幕可幫助您訪
問生産環境中正在運作的應用程式的目前狀态。有幾個名額必須在生産環境中進行檢查和
監控。即使一些外部應用程式可能正在使用這些服務來向相關人員觸發警報消息。螢幕
子產品公開了一組可直接作為 HTTP URL 通路的 REST 端點來檢查狀态。
問題六
如何在 Spring Boot 中禁用 Actuator 端點安全性?
預設情況下,所有敏感的 HTTP 端點都是安全的,隻有具有 ACTUATOR 角色的使用者才能訪
問它們。安全性是使用标準的 HttpServletRequest.isUserInRole 方法實施的。 我們可以使用
management.security.enabled = false
來禁用安全性。隻有在執行機構端點在防火牆後通路時,才建議禁用安全性。
如何在自定義端口上運作 Spring Boot 應用程式?
為了在自定義端口上運作 Spring Boot 應用程式,您可以在 application.properties 中指定端口。
server.port = 8090
什麼是 YAML?
YAML 是一種人類可讀的資料序列化語言。它通常用于配置檔案。
與屬性檔案相比,如果我們想要在配置檔案中添加複雜的屬性,YAML 檔案就更加結構
化,而且更少混淆。可以看出 YAML 具有分層配置資料。
如何實作 Spring Boot 應用程式的安全性?
為了實作 Spring Boot 的安全性,我們使用 spring-boot-starter-security 依賴項,并且必須添
加安全配置。它隻需要很少的代碼。配置類将必須擴充 WebSecurityConfigurerAdapter 并覆
蓋其方法。