1.什么是SpringBoot?
多年來,隨著新功能的增加,spring 變得越來越復雜。只需訪問 https://spring.io/projects頁面,我們就會看到可以在我們的應用程序中使用的所有 Spring 項目的不同功能。如果必須啟動一個新的 Spring 項目,我們必須添加構建路徑或添加 Maven 依賴關系,配置應用程序服務器,添加 spring 配置。因此,開始一個新的 spring 項目需要很多努力,因為我們現(xiàn)在必須從頭開始做所有事情。
Spring Boot 是解決這個問題的方法。Spring Boot 已經建立在現(xiàn)有 spring 框架之上。使用spring 啟動,我們避免了之前我們必須做的所有樣板代碼和配置。因此,Spring Boot 可以幫助我們以最少的工作量,更加健壯地使用現(xiàn)有的 Spring 功能。
2.SpringBoot有那些優(yōu)點?
減少開發(fā),測試時間和努力。
使用 JavaConfig 有助于避免使用 XML。
避免大量的 Maven 導入和各種版本沖突。
提供意見發(fā)展方法。
通過提供默認值快速開始開發(fā)。
沒有單獨的 Web 服務器需要。這意味著你不再需要啟動 Tomcat,Glassfish 或其他任何東西。
需要更少的配置,因為沒有 web.xml 文件。只需添加用@Configuration 注釋的類,然后添加用@Bean 注釋的方法,Spring將自動加載對象并像以前一樣對其進行管理。您甚至可以將@Autowired添加到bean方法中,以使 Spring自動裝入需要的依賴關系中。
基于環(huán)境的配置使用這些屬性,您可以將您正在使用的環(huán)境傳遞到應用程序:-Dspring.profiles.active={enviornment}。在加載主應用程序屬性文件后,Spring 將在(application{environment} .properties)中加載后續(xù)的應用程序屬性文件。
3.什么是JavaConfig?
Spring JavaConfig 是 Spring 社區(qū)的產品,它提供了配置 Spring IoC 容器的純 Java 方法。因此它有助于避免使用 XML 配置。使用 JavaConfig 的優(yōu)點在于:
面向對象的配置。由于配置被定義為 JavaConfig 中的類,因此用戶可以充分利用 Java 中的面向對象功能。一個配置類可以繼承另一個,重寫它的@Bean 方法等。
減少或消除 XML 配置?;谝蕾囎⑷朐瓌t的外化配置的好處已被證明。但是,許多開發(fā)人員不希望在 XML 和 Java 之間來回切換。JavaConfig 為開發(fā)人員提供了一種純 Java 方法來配置與 XML 配置概念相似的 Spring 容器。從技術角度來講,只使用 JavaConfig 配置類來配置容器是可行的,但實際上很多人認為將 JavaConfig 與 XML 混合匹配是理想的。
類型安全和重構友好。JavaConfig 提供了一種類型安全的方法來配置 Spring 容器。由于Java 5.0 對泛型的支持,現(xiàn)在可以按類型而不是按名稱檢索 bean,不需要任何強制轉換或基于字符串的查找。
4.如何重新加載SpringBoot上的更改,而無需重新啟動服務器?
這可以使用DEV工具來實現(xiàn)。通過這種依賴關系,您可以節(jié)省任何更改,嵌入式tomcat將重新啟動。SpringBoot有一個開發(fā)工具(DevTools)模塊,它有助于提高開發(fā)人員的生產力。Java開發(fā)人員面臨的一個主要挑戰(zhàn)是將文件更改自動部署到服務器并自動重啟服務器。開發(fā)人員可以重新加載 SpringBoot 上的更改,而無需重新啟動服務器。這將消除每次手動部署更改的需要。SpringBoot在發(fā)布它的第一個版本時沒有這個功能。這是開發(fā)人員最需要的功能。DevTools模塊完全滿足開發(fā)人員的需求。該模塊將在生產環(huán)境中被禁用。它還提供H2數(shù)據(jù)庫控制臺以更好地測試應用程序。
org.springframework.boot spring-boot-devtools
5.SpringBoot 中的監(jiān)視器是什么?
Springboot actuator 是spring 啟動框架中的重要功能之一。Springboot 監(jiān)視器可幫助您訪問生產環(huán)境中正在運行的應用程序的當前狀態(tài)。有幾個指標必須在生產環(huán)境中進行檢查和監(jiān)控。即使一些外部應用程序可能正在使用這些服務來向相關人員觸發(fā)警報消息。監(jiān)視器模塊公開了一組可直接作為 HTTP URL 訪問的REST端點來檢查狀態(tài)。
6.如何在SpringBoot中禁用Actuator端點安全性?
默認情況下,所有敏感的 HTTP 端點都是安全的,只有具有 ACTUATOR 角色的用戶才能訪問它們。安全性是使用標準的 HttpServletRequest.isUserInRole 方法實施的。 我們可以使用management.security.enabled = false來禁用安全性。只有在執(zhí)行機構端點在防火墻后訪問時,才建議禁用安全性。
7.如何在自定義端口上運行 Spring Boot 應用程序?
為了在自定義端口上運行 Spring Boot 應用程序,您可以在 application.properties 中指定端口。
server.port = 8090
8.什么是 YAML?
YAML是一種人類可讀的數(shù)據(jù)序列化語言。它通常用于配置文件。
與屬性文件相比,如果我們想要在配置文件中添加復雜的屬性,YAML 文件就更加結構化,而且更少混淆??梢钥闯鯵AML具有分層配置數(shù)據(jù)。
9.如何實現(xiàn)SpringBoot應用程序的安全性?
為了實現(xiàn) SpringBoot 的安全性,我們使用spring-boot-starter-security 依賴項,并且必須添加安全配置。它只需要很少的代碼。配置類將必須擴展WebSecurityConfigurerAdapter并覆蓋其方法。
10.什么是Swagger?你用SpringBoot實現(xiàn)了它嗎?
Swagger 廣泛用于可視化 API,使用 Swagger UI 為前端開發(fā)人員提供在線沙箱。Swagger 是用于生成 RESTful Web 服務的可視化表示的工具,規(guī)范和完整框架實現(xiàn)。它使文檔能夠以與服務器相同的速度更新。當通過 Swagger 正確定義時,消費者可以使用最少量的實現(xiàn)邏輯來理解遠程服務并與其進行交互。因此,Swagger 消除了調用服務時的猜測。
11.什么是 Spring Profiles?
Spring Profiles 允許用戶根據(jù)配置文件(dev,test,prod 等)來注冊 bean。因此,當應用程序在開發(fā)中運行時,只有某些 bean 可以加載,而在PRODUCTION中,某些其他bean可以加載。假設我們的要求是 Swagger文檔僅適用于 QA 環(huán)境,并且禁用所有其他文檔。這可以使用配置文件來完成。Spring Boot 使得使用配置文件非常簡單。
12.什么是SpringBatch?
Spring Boot Batch 提供可重用的函數(shù),這些函數(shù)在處理大量記錄時非常重要,包括日志/跟蹤,事務管理,作業(yè)處理統(tǒng)計信息,作業(yè)重新啟動,跳過和資源管理。它還提供了更先進的技術服務和功能,通過優(yōu)化和分區(qū)技術,可以實現(xiàn)極高批量和高性能批處理作業(yè)。簡單以及復雜的大批量批處理作業(yè)可以高度可擴展的方式利用框架處理重要大量的信息。
13.什么是freemarker模板?
freemarker是一個基于Java的模板引擎,最初專注于使用MVC軟件架構進行動態(tài)網(wǎng)頁生成。使用freemarker的主要優(yōu)點是表示層和業(yè)務層的完全分離。程序員可以處理應用程序代碼,而設計人員可以處理 html 頁面設計。最后使用freemarker可以將這些結合起來,給出最終的輸出頁面。
14.如何使用SpringBoot實現(xiàn)異常處理?
Spring提供了一種使用ControllerAdvice 處理異常的非常有用的方法。 我們通過實現(xiàn)一個ControlerAdvice類,來處理控制器類拋出的所有異常。
15.您使用了哪些starter maven依賴項?
使用了下面的一些依賴項
spring-boot-starter-activemq
spring-boot-starter-security
spring-boot-starter-web
這有助于增加更少的依賴關系,并減少版本的沖突。
16.什么是CSRF攻擊?
CSRF代表跨站請求偽造。這是一種攻擊,迫使最終用戶在當前通過身份驗證的Web應用程序上執(zhí)行不需要的操作。CSRF攻擊專門針對狀態(tài)改變請求,而不是數(shù)據(jù)竊取,因為攻擊者無法查看對偽造請求的響應。
17.什么是 AOP?
在軟件開發(fā)過程中,跨越應用程序多個點的功能稱為交叉問題。這些交叉問題與應用程序的主要業(yè)務邏輯不同。因此,將這些橫切關注與業(yè)務邏輯分開是面向方面編程(AOP)的地方。
18.我們如何監(jiān)視所有SpringBoot微服務?
SpringBoot 提供監(jiān)視器端點以監(jiān)控各個微服務的度量。這些端點對于獲取有關應用程序的信息(如它們是否已啟動)以及它們的組件(如數(shù)據(jù)庫等)是否正常運行很有幫助。但是,使用監(jiān)視器的一個主要缺點或困難是,我們必須單獨打開應用程序的知識點以了解其狀態(tài)或健康狀況。想象一下涉及50個應用程序的微服務,管理員將不得不擊中所有50個應用程序的執(zhí)行終端。
我是嬈疆_蚩夢,讓堅持成為一種習慣,感謝各位大佬的:點贊、收藏和評論,我們下期見!