1. 程式人生 > >Spring Boot 面試題整理

Spring Boot 面試題整理

網上搜集整理

Spring Boot 是微服務中最好的 Java 框架

問題一: Spring Boot、Spring MVC 和 Spring 有什麼區別?

SpringFrame

SpringFramework 最重要的特徵是依賴注入。所有 SpringModules 不是依賴注入就是 IOC 控制反轉。

當我們恰當的使用 DI 或者是 IOC 的時候,我們可以開發鬆耦合應用。鬆耦合應用的單元測試可以很容易的進行。

SpringMVC

Spring MVC 提供了一種分離式的方法來開發 Web 應用。通過運用像 DispatcherServelet,MoudlAndView 和 ViewResolver 等一些簡單的概念,開發 Web 應用將會變的非常簡單。

SpringBoot

Spring 和 SpringMVC 的問題在於需要配置大量的引數。

<bean
 class="org.springframework.web.servlet.view.InternalResourceViewResolver">
<property name="prefix">
        <value>/WEB-INF/views/</value>
    </property>
    <property name="suffix">
        <value>.jsp</value>
    </property>
  </bean>
  
  <mvc:resources mapping="/webjars/**" location="/webjars/"/>

Spring Boot 通過一個自動配置和啟動的項來目解決這個問題。為了更快的構建產品就緒應用程式,Spring Boot 提供了一些非功能性特徵

問題二:什麼是自動配置?

Spring 和 SpringMVC 的問題在於需要配置大量的引數。

我們能否帶來更多的智慧?當一個 MVC JAR 新增到應用程式中的時候,我們能否自動配置一些 beans?

Spring 檢視(CLASSPATH 上可用的框架)已存在的應用程式的配置。在此基礎上,Spring Boot 提供了配置應用程式和框架所需要的基本配置。這就是自動配置

問題三:什麼是 Spring Boot Stater ?

這些依賴項。Spring Boot Starter Web 預先打包了這些依賴項。

作為一個開發者,我不需要再擔心這些依賴項和它們的相容版本

問題六: Spring 是如何快速建立產品就緒應用程式的?

Spring Boot 致力於快速產品就緒應用程式。為此,它提供了一些譬如快取記憶體,日誌記錄,監控和嵌入式伺服器等開箱即用的非功能性特徵。

spring-boot-starter-actuator - 使用一些如監控和跟蹤應用的高階功能

spring-boot-starter-undertow, spring-boot-starter-jetty, spring-boot-starter-tomcat - 選擇您的特定嵌入式 Servlet 容器

spring-boot-starter-logging - 使用 logback 進行日誌記錄

spring-boot-starter-cache - 啟用 Spring Framework 的快取支援

###Spring2 和 Spring5 所需要的最低 Java 版本是什麼?

Spring Boot 2.0 需要 Java8 或者更新的版本。Java6 和 Java7 已經不再支援

問題七:為什麼我們需要 spring-boot-maven-plugin?

spring-boot-maven-plugin 提供了一些像 jar 一樣打包或者執行應用程式的命令。

  • spring-boot:run 執行你的 SpringBooty 應用程式。
  • spring-boot:repackage 重新打包你的 jar 包或者是 war 包使其可執行
  • spring-boot:start 和 spring-boot:stop 管理 Spring Boot 應用程式的生命週期(也可以說是為了整合測試)。
  • spring-boot:build-info 生成執行器可以使用的構造資訊。

問題八 如何使用 SpringBoot 自動重灌我的應用程式?

使用 Spring Boot 開發工具。

把 Spring Boot 開發工具新增進入你的專案是簡單的。

把下面的依賴項新增至你的 Spring Boot Project pom.xml 中

<dependency>
     <groupId>org.springframework.boot</groupId>
     <artifactId>spring-boot-devtools</artifactId>
     <scope>runtime</scope>
</dependency>

重啟應用程式,然後就可以了。

問題九 什麼是嵌入式伺服器?我們為什麼要使用嵌入式伺服器呢?

思考一下在你的虛擬機器上部署應用程式需要些什麼。

第一步: 安裝 Java

第二部: 安裝 Web 或者是應用程式的伺服器(Tomat/Wbesphere/Weblogic 等等)

第三部: 部署應用程式 war 包

如果我們想簡化這些步驟,應該如何做呢?

讓我們來思考如何使伺服器成為應用程式的一部分?

你只需要一個安裝了 Java 的虛擬機器,就可以直接在上面部署應用程式了,
是不是很爽?

這個想法是嵌入式伺服器的起源。

當我們建立一個可以部署的應用程式的時候,我們將會把伺服器(例如,tomcat)嵌入到可部署的伺服器中。

例如,對於一個 Spring Boot 應用程式來說,你可以生成一個包含 Embedded Tomcat 的應用程式 jar。你就可以想執行正常 Java 應用程式一樣來執行 web 應用程式了。

嵌入式伺服器就是我們的可執行單元包含伺服器的二進位制檔案(例如,tomcat.jar)。

問題十 如何使用 Spring Boot 部署到不同的伺服器?

你需要做下面兩個步驟:

  • 在一個專案中生成一個 war 檔案。

  • 將它部署到你最喜歡的伺服器(websphere 或者 Weblogic 或者 Tomcat and so on)。

問題十一 RequestMapping 和 GetMapping 的不同之處在哪裡?

  • RequestMapping 具有類屬性的,可以進行 GET,POST,PUT 或者其它的註釋中具有的請求方法。

  • GetMapping 是 GET 請求方法中的一個特例。它只是 ResquestMapping 的一個延伸,目的是為了提高清晰度。

問題十二為什麼我們不建議在實際的應用程式中使用 Spring Data Rest?

我們認為 Spring Data Rest 很適合快速原型製造!在大型應用程式中使用需要謹慎。

通過 Spring Data REST 你可以把你的資料實體作為 RESTful 服務直接釋出。

當你設計 RESTful 伺服器的時候,最佳實踐表明,你的介面應該考慮到兩件重要的事情:

  • 你的模型範圍。
  • 你的客戶。

通過 With Spring Data REST,你不需要再考慮這兩個方面,只需要作為 TEST 服務釋出實體。

這就是為什麼我們建議使用 Spring Data Rest 在快速原型構造上面,或者作為專案的初始解決方法。對於完整演變專案來說,這並不是一個好的注意。

問題十三 JPA 和 Hibernate 有哪些區別?

簡而言之

  • JPA 是一個規範或者介面
  • Hibernate 是 JPA 的一個實現

當我們使用 JPA 的時候,我們使用 javax.persistence 包中的註釋和介面時,不需要使用 hibernate 的匯入包。

我們建議使用 JPA 註釋,因為哦我們沒有將其繫結到 Hibernate 作為實現。後來(我知道 - 小於百分之一的機率),我們可以使用另一種 JPA 實現。

問題十四 業務邊界應該從哪一層開始?

我們建議在服務層管理義務。商業業務邏輯在商業層或者服務層,與此同時,你想要執行的業務管理也在該層。

問題十五 如何不通過任何配置來選擇 Hibernate 作為 JPA 的預設實現?

因為 Spring Boot 是自動配置的。

下面是我們新增的依賴項

<dependency>
           <groupId>org.springframework.boot</groupId>
           <artifactId>spring-boot-starter-data-jpa</artifactId>
      </dependency>

spring-boot-stater-data-jpa 對於 Hibernate 和 JPA 有過渡依賴性。

當 Spring Boot 在類路徑中檢測到 Hibernate 中,將會自動配置它為預設的 JPA 實現。

問題十七 指定的資料庫連線資訊在哪裡?它是如何知道自動連線至 H2 的?

這就是 Spring Boot 自動配置的魔力。

Spring Boot auto-configuration 試圖自動配置你已經新增的基於 jar 依賴項的 Spring 應用程式。比如說,如果 HSQLDBis 存在你的類路徑中,並且,資料庫連線 bean 還沒有手動配置,那麼我們可以自動配置一個記憶體資料庫。

進一步的閱讀:

第十八題,我們如何連線一個像 MSSQL 或者 orcale 一樣的外部資料庫?

讓我們以 MySQL 為例來思考這個問題:

第一步 - 把 mysql 聯結器的依賴項新增至 pom.xml

<dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
</dependency>

第二步 - 從 pom.xml 中移除 H2 的依賴項

或者至少把它作為測試的範圍。

<!--
<dependency>
    <groupId>com.h2database</groupId>
    <artifactId>h2</artifactId>
<scope>test</scope>
</dependency>
-->   

第三步 - 安裝你的 MySQL 資料庫

第四步 - 配置你的 MySQL 資料庫連線

配置 application.properties

spring.jpa.hibernate.ddl-auto=none
spring.datasource.url=jdbc:mysql://localhost:3306/todo_example
spring.datasource.username=todouser
spring.datasource.password=YOUR_PASSWORD   

第五步 - 重新啟動,你就準備好了!

就是這麼簡單!

問題十九釋出 Spring Boot 使用者應用程式自定義配置的最好方法是什麼?

@Value 的問題在於,您可以通過應用程式分配你配置值。更好的操作是採取集中的方法。
你可以使用 @ConfigurationProperties 定義一個配置元件。

@Component
@ConfigurationProperties("basic")
public class BasicConfiguration {
    private boolean value;
    private String message;
    private int number;

你可以在 application.properties 中配置引數。

basic.value: true
basic.message: Dynamic Message
basic.number: 100

問題二十 配置檔案的需求是什麼?

企業應用程式的開發是複雜的,你需要混合的環境:

  • Dev
  • QA
  • Stage
  • Production

在每個環境中,你想要不同的應用程式配置。

配置檔案有助於在不同的環境中進行不同的應用程式配置。

Spring 和 Spring Boot 提供了你可以制定的功能。

  • 不同配置檔案中,不同環境的配置是什麼?
  • 為一個制定的環境設定活動的配置檔案。

Spring Boot 將會根據特定環境中設定的活動配置檔案來選擇應用程式的配置。

## 問題三十四 如何使用配置檔案通過 Spring Boot 配置特定環境的配置?

配置檔案不是設別環境的關鍵。

在下面的例子中,我們將會用到兩個配置檔案

  • dev
  • prod

預設的應用程式配置在 application.properties 中。讓我們來看下面的例子:

application.properties

basic.value= true
basic.message= Dynamic Message
basic.number= 100

我們想要為 dev 檔案自定義 application.properties 屬性。我們需要建立一個名為 application-dev.properties 的檔案,並且重寫我們想要自定義的屬性。

application-dev.properties

basic.message: Dynamic Message in DEV

一旦你特定配置了配置檔案,你需要在環境中設定一個活動的配置檔案。

有多種方法可以做到這一點:

  • 在 VM 引數中使用 Dspring.profiles.active=prod
  • 在 application.properties 中使用 spring.profiles.active=prod

一. 什麼是springboot

1.用來簡化spring應用的初始搭建以及開發過程 使用特定的方式來進行配置(properties或yml檔案)
2.建立獨立的spring引用程式 main方法執行
3.嵌入的Tomcat 無需部署war檔案
4.簡化maven配置
5.自動配置spring新增對應功能starter自動化配置

二.springboot常用的starter有哪些

可以去Maven倉庫中搜索以下外掛,pom檔案依賴即可
Maven倉庫官網:http://mvnrepository.com/
1.spring-boot-starter-web (嵌入tomcat和web開發需要servlet與jsp支援)
2.spring-boot-starter-data-jpa (資料庫支援)
3.spring-boot-starter-data-redis (redis資料庫支援)
4.spring-boot-starter-data-solr (solr搜尋應用框架支援)
5.mybatis-spring-boot-starter (第三方的mybatis整合starter)

三. springboot自動配置的原理

[email protected]這個註釋告訴SpringBoot“猜”你將如何想配置Spring,基於你已經新增jar依賴項。如果spring-boot-starter-web已經新增Tomcat和Spring MVC,這個註釋自動將假設您正在開發一個web應用程式並新增相應的spring設定。會自動去maven中讀取每個starter中的spring.factories檔案 該檔案裡配置了所有需要被建立spring容器中的bean

2.使用@SpringbootApplication註解 可以解決根類或者配置類(我自己的說法,就是main所在類)頭上註解過多的問題,一個@SpringbootApplication相當於@Configuration,@EnableAutoConfiguration和 @ComponentScan 並具有他們的預設屬性值

四.springboot讀取配置檔案的方式

    springboot預設讀取配置檔案為application.properties或者是application.yml



作者:HaleyLiu
連結:https://www.jianshu.com/p/0674c1544edf
來源:簡書
簡書著作權歸作者所有,任何形式的轉載都請聯絡作者獲得授權並註明出處。

五. springboot如何新增【修改程式碼】自動重啟功能

    新增開發者工具集=====spring-boot-devtools

六.微服務

    以前的模式是 所有的程式碼在同一個工程中 部署在同一個伺服器中 同一個專案的不同模組不同功能互相搶佔資源
    微服務 將工程根據不同的業務規則拆分成微服務 微服務部署在不同的機器上 服務之間進行相互呼叫
    Java微服務的框架有 dubbo(只能用來做微服務),spring cloud(提供了服務的發現,斷路器等)

七. springcloud如何實現服務的註冊和發現

    服務在釋出時 指定對應的服務名(服務名包括了IP地址和埠) 將服務註冊到註冊中心(eureka或者zookeeper)
    這一過程是springcloud自動實現 只需要在main方法新增@EnableDisscoveryClient  同一個服務修改埠就可以啟動多個例項
    呼叫方法:傳遞服務名稱通過註冊中心獲取所有的可用例項 通過負載均衡策略呼叫(ribbon和feign)對應的服務



作者:HaleyLiu
連結:https://www.jianshu.com/p/0674c1544edf
來源:簡書
簡書著作權歸作者所有,任何形式的轉載都請聯絡作者獲得授權並註明出處。

1.常見的starter會包幾個方面的內容?分別是什麼?

// 常見的starter會包括下面四個方面的內容

// 自動配置檔案,根據classpath是否存在指定的類來決定是否要執行該功能的自動配置。

// spring.factories,非常重要,指導Spring Boot找到指定的自動配置檔案。

// endpoint:可以理解為一個admin,包含對服務的描述、介面、互動(業務資訊的查詢)。

// health indicator:該starter提供的服務的健康指標。

兩個需要注意的點:

  // 1. @ConditionalOnMissingBean的作用是:只有對應的bean在系統中都沒有被建立,它修飾的初始化程式碼塊才會執行,【使用者自己手動建立的bean優先】。

// 2. Spring Boot Starter找到自動配置檔案(xxxxAutoConfiguration之類的檔案)的方式有兩種:

// spring.factories:由Spring Boot觸發探測classpath目錄下的類,進行自動配置;

// @EnableXxxxx:有時需要由starter的使用者觸發*查詢自動配置檔案的過程

2.總結Spring Boot Starter的工作原理

// Spring Boot Starter的工作原理如下:

// 1. Spring Boot 在啟動時掃描專案所依賴的JAR包,尋找包含spring.factories檔案的JAR

// 2. 根據spring.factories配置載入AutoConfigure類

// 3. 根據 @Conditional註解的條件,進行自動配置並將Bean注入Spring Context

3.談談你對Spring Boot的認識。

// spring Boot是一個開源框架,它可用於建立可執行的Spring應用程式,採用了習慣優於配置的方法。此框架的神奇之處在於@EnableAutoConfiguration註解,此註解自動載入應用程式所需的所有Bean——這依賴於Spring Boot在類路徑中的查詢。

1. @Enable*註解

@Enable*註解並不是新發明的註解,早在Spring 3框架就引入了這些註解,用這些註解替代XML配置檔案。 
很多Spring開發者都知道@EnableTransactionManagement註解,它能夠宣告事務管理;@EnableWebMvc註解,它能啟用Spring MVC;以及@EnableScheduling註解,它可以初始化一個排程器。 

2. 屬性對映

下面看MongoProperties類,它是一個Spring Boot屬性對映的例子:

@ConfigurationProperties(prefix = "spring.data.mongodb")
public class MongoProperties {

    private String host;
    private int port = DBPort.PORT;
    private String uri = "mongodb://localhost/test";
    private String database;

    // ... getters/ setters omitted
}
@ConfigurationProperties註解將POJO關聯到指定字首的每一個屬性。例如,spring.data.mongodb.port屬性將對映到這個類的埠屬性。 
強烈建議Spring Boot開發者使用這種方式來刪除與配置屬性相關的瓶頸程式碼。

[email protected]註解

Spring Boot的強大之處在於使用了Spring 4框架的新特性:@Conditional註解,此註解使得只有在特定條件滿足時才啟用一些配置。 
在Spring Boot的org.springframework.boot.autoconfigure.condition包中說明了使用@Conditional註解能給我們帶來什麼,下面對這些註解做一個概述:

@ConditionalOnBean
@ConditionalOnClass
@ConditionalOnExpression
@ConditionalOnMissingBean
@ConditionalOnMissingClass
@ConditionalOnNotWebApplication
@ConditionalOnResource
@ConditionalOnWebApplication

4.應用程式上下文初始化器

spring.factories還提供了第二種可能性,即定義應用程式的初始化。這使得我們可以在應用程式載入前操縱Spring的應用程式上下文ApplicationContext。 
特別是,可以在上下文建立監聽器,使用ConfigurableApplicationContext類的addApplicationListener()方法。 
AutoConfigurationReportLoggingInitializer監聽到系統事件時,比如上下文重新整理或應用程式啟動故障之類的事件,Spring Boot可以執行一些工作。這有助於我們以除錯模式啟動應用程式時建立自動配置的報告。 
要以除錯模式啟動應用程式,可以使用-Ddebug標識,或者在application.properties檔案這新增屬性debug= true。

4.自定義springboot-starter注意事項

// 1. springboot預設scan的包名是其main類所在的包名。如果引入的starter包名不一樣,需要自己新增scan。

@ComponentScan(basePackages = {"com.xixicat.demo","com.xixicat.sms"})

// 2. 對於starter中有feign的,需要額外指定

@EnableFeignClients(basePackages = {"com.xixicat.sms"})

// 3. 對於exclude一些autoConfig

@EnableAutoConfiguration(exclude = {MetricFilterAutoConfiguration.class})

Spring 概述

1. 什麼是spring?

Spring 是個java企業級應用的開源開發框架。Spring主要用來開發Java應用,但是有些擴充套件是針對構建J2EE平臺的web應用。Spring 框架目標是簡化Java企業級應用開發,並通過POJO為基礎的程式設計模型促進良好的程式設計習慣。

2. 使用Spring框架的好處是什麼?

  • 輕量:Spring 是輕量的,基本的版本大約2MB。
  • 控制反轉:Spring通過控制反轉實現了鬆散耦合,物件們給出它們的依賴,而不是建立或查詢依賴的物件們。
  • 面向切面的程式設計(AOP):Spring支援面向切面的程式設計,並且把應用業務邏輯和系統服務分開。
  • 容器:Spring 包含並管理應用中物件的生命週期和配置。
  • MVC框架:Spring的WEB框架是個精心設計的框架,是Web框架的一個很好的替代品。
  • 事務管理:Spring 提供一個持續的事務管理介面,可以擴充套件到上至本地事務下至全域性事務(JTA)。
  • 異常處理:Spring 提供方便的API把具體技術相關的異常(比如由JDBC,Hibernate or JDO丟擲的)轉化為一致的unchecked 異常。

3. Spring由哪些模組組成?

以下是Spring 框架的基本模組:

  • Core module
  • Bean module
  • Context module
  • Expression Language module
  • JDBC module
  • ORM module
  • OXM module
  • Java Messaging Service(JMS) module
  • Transaction module
  • Web module
  • Web-Servlet module
  • Web-Struts module
  • Web-Portlet module

4. 核心容器(應用上下文) 模組

這是基本的Spring模組,提供spring 框架的基礎功能,BeanFactory 是 任何以spring為基礎的應用的核心。Spring 框架建立在此模組之上,它使Spring成為一個容器。

5. BeanFactory – BeanFactory 實現舉例。

Bean 工廠是工廠模式的一個實現,提供了控制反轉功能,用來把應用的配置和依賴從正真的應用程式碼中分離。

最常用的BeanFactory 實現是XmlBeanFactory 類。

6. XMLBeanFactory

最常用的就是org.springframework.beans.factory.xml.XmlBeanFactory ,它根據XML檔案中的定義載入beans。該容器從XML 檔案讀取配置元資料並用它去建立一個完全配置的系統或應用。

7. 解釋AOP模組

AOP模組用於發給我們的Spring應用做面向切面的開發, 很多支援由AOP聯盟提供,這樣就確保了Spring和其他AOP框架的共通性。這個模組將元資料程式設計引入Spring。

8. 解釋JDBC抽象和DAO模組

通過使用JDBC抽象和DAO模組,保證資料庫程式碼的簡潔,並能避免資料庫資源錯誤關閉導致的問題,它在各種不同的資料庫的錯誤資訊之上,提供了一個統一的異常訪問層。它還利用Spring的AOP 模組給Spring應用中的物件提供事務管理服務。

9. 解釋物件/關係對映整合模組

Spring 通過提供ORM模組,支援我們在直接JDBC之上使用一個物件/關係對映對映(ORM)工具,Spring 支援整合主流的ORM框架,如Hiberate,JDO和 iBATIS SQL Maps。Spring的事務管理同樣支援以上所有ORM框架及JDBC。

10. 解釋WEB 模組

Spring的WEB模組是構建在application context 模組基礎之上,提供一個適合web應用的上下文。這個模組也包括支援多種面向web的任務,如透明地處理多個檔案上傳請求和程式級請求引數的繫結到你的業 務物件。它也有對Jakarta Struts的支援。

12. Spring配置檔案

Spring配置檔案是個XML 檔案,這個檔案包含了類資訊,描述瞭如何配置它們,以及如何相互呼叫。

13. 什麼是Spring IOC 容器?

Spring IOC 負責建立物件,管理物件(通過依賴注入(DI),裝配物件,配置物件,並且管理這些物件的整個生命週期。

14. IOC的優點是什麼?

IOC 或 依賴注入把應用的程式碼量降到最低。它使應用容易測試,單元測試不再需要單例和JNDI查詢機制。最小的代價和最小的侵入性使鬆散耦合得以實現。IOC容器支援載入服務時的餓漢式初始化和懶載入。

15. ApplicationContext通常的實現是什麼?

  • FileSystemXmlApplicationContext :此容器從一個XML檔案中載入beans的定義,XML Bean 配置檔案的全路徑名必須提供給它的建構函式。
  • ClassPathXmlApplicationContext:此容器也從一個XML檔案中載入beans的定義,這裡,你需要正確設定classpath因為這個容器將在classpath裡找bean配置。
  • WebXmlApplicationContext:此容器載入一個XML檔案,此檔案定義了一個WEB應用的所有bean。

16. Bean 工廠和 Application contexts 有什麼區別?

Application contexts提供一種方法處理文字訊息,一個通常的做法是載入檔案資源(比如映象),它們可以向註冊為監聽器的bean釋出事件。另外,在容器或容器 內的物件上執行的那些不得不由bean工廠以程式化方式處理的操作,可以在Application contexts中以宣告的方式處理。Application contexts實現了MessageSource介面,該介面的實現以可插拔的方式提供獲取本地化訊息的方法。

17. 一個Spring的應用看起來象什麼?

  • 一個定義了一些功能的介面。
  • 這實現包括屬性,它的Setter , getter 方法和函式等。
  • Spring AOP。
  • Spring 的XML 配置檔案。
  • 使用以上功能的客戶端程式。

依賴注入

18. 什麼是Spring的依賴注入

依賴注入,是IOC的一個方面,是個通常的概念,它有多種解釋。這概念是說你不用建立物件,而只需要描述它如何被建立。你不在程式碼裡直接組裝你的元件和服務,但是要在配置檔案裡描述哪些元件需要哪些服務,之後一個容器(IOC容器)負責把他們組裝起來。

19. 有哪些不同型別的IOC(依賴注入)方式?

  • 構造器依賴注入:構造器依賴注入通過容器觸發一個類的構造器來實現的,該類有一系列引數,每個引數代表一個對其他類的依賴。
  • Setter方法注入:Setter方法注入是容器通過呼叫無參構造器或無參static工廠 方法例項化bean之後,呼叫該bean的setter方法,即實現了基於setter的依賴注入。

20. 哪種依賴注入方式你建議使用,構造器注入,還是 Setter方法注入?

你兩種依賴方式都可以使用,構造器注入和Setter方法注入。最好的解決方案是用構造器引數實現強制依賴,setter方法實現可選依賴。

Spring Beans

21.什麼是Spring beans?

Spring beans 是那些形成Spring應用的主幹的java物件。它們被Spring IOC容器初始化,裝配,和管理。這些beans通過容器中配置的元資料建立。比如,以XML檔案中<bean/> 的形式定義。

Spring 框架定義的beans都是單件beans。在bean tag中有個屬性”singleton”,如果它被賦為TRUE,bean 就是單件,否則就是一個 prototype bean。預設是TRUE,所以所有在Spring框架中的beans 預設都是單件。

22. 一個 Spring Bean 定義 包含什麼?

一個Spring Bean 的定義包含容器必知的所有配置元資料,包括如何建立一個bean,它的生命週期詳情及它的依賴。

23. 如何給Spring 容器提供配置元資料?

這裡有三種重要的方法給Spring 容器提供配置元資料。

XML配置檔案。

基於註解的配置。

基於java的配置。

24. 你怎樣定義類的作用域?

當定義一個<bean> 在Spring裡,我們還能給這個bean宣告一個作用域。它可以通過bean 定義中的scope屬性來定義。如,當Spring要在需要的時候每次生產一個新的bean例項,bean的scope屬性被指定為prototype。 另一方面,一個bean每次使用的時候必須返回同一個例項,這個bean的scope 屬性 必須設為 singleton。

25. 解釋Spring支援的幾種bean的作用域。

Spring框架支援以下五種bean的作用域:

  • singleton : bean在每個Spring ioc 容器中只有一個例項。
  • prototype:一個bean的定義可以有多個例項。
  • request:每次http請求都會建立一個bean,該作用域僅在基於web的Spring ApplicationContext情形下有效。
  • session:在一個HTTP Session中,一個bean定義對應一個例項。該作用域僅在基於web的Spring ApplicationContext情形下有效。
  • global-session:在一個全域性的HTTP Session中,一個bean定義對應一個例項。該作用域僅在基於web的Spring ApplicationContext情形下有效。

預設的Spring bean 的作用域是Singleton.

26. Spring框架中的單例bean是執行緒安全的嗎?

不,Spring框架中的單例bean不是執行緒安全的。

27. 解釋Spring框架中bean的生命週期。

  • Spring容器 從XML 檔案中讀取bean的定義,並例項化bean。
  • Spring根據bean的定義填充所有的屬性。
  • 如果bean實現了BeanNameAware 介面,Spring 傳遞bean 的ID 到 setBeanName方法。
  • 如果Bean 實現了 BeanFactoryAware 介面, Spring傳遞beanfactory 給setBeanFactory 方法。
  • 如果有任何與bean相關聯的BeanPostProcessors,Spring會在postProcesserBeforeInitialization()方法內呼叫它們。
  • 如果bean實現IntializingBean了,呼叫它的afterPropertySet方法,如果bean聲明瞭初始化方法,呼叫此初始化方法。
  • 如果有BeanPostProcessors 和bean 關聯,這些bean的postProcessAfterInitialization() 方法將被呼叫。
  • 如果bean實現了 DisposableBean,它將呼叫destroy()方法。

28. 哪些是重要的bean生命週期方法? 你能過載它們嗎?

有兩個重要的bean 生命週期方法,第一個是setup , 它是在容器載入bean的時候被呼叫。第二個方法是 teardown 它是在容器解除安裝類的時候被呼叫。

The bean 標籤有兩個重要的屬性(init-method和destroy-method)。用它們你可以自己定製初始化和登出方法。它們也有相應的註解(@PostConstruct和@PreDestroy)。

29. 什麼是Spring的內部bean?

當一個bean僅被用作另一個bean的屬性時,它能被宣告為一個內部bean,為了定義inner bean,在Spring 的 基於XML的 配置元資料中,可以在 <property/>或 <constructor-arg/> 元素內使用<bean/> 元素,內部bean通常是匿名的,它們的Scope一般是prototype。

30. 在 Spring中如何注入一個java集合?

Spring提供以下幾種集合的配置元素:

  • <list>型別用於注入一列值,允許有相同的值。
  • <set> 型別用於注入一組值,不允許有相同的值。
  • <map> 型別用於注入一組鍵值對,鍵和值都可以為任意型別。
  • <props>型別用於注入一組鍵值對,鍵和值都只能為String型別。

31. 什麼是bean裝配?

裝配,或bean 裝配是指在Spring 容器中把bean組裝到一起,前提是容器需要知道bean的依賴關係,如何通過依賴注入來把它們裝配到一起。

32. 什麼是bean的自動裝配?

Spring 容器能夠自動裝配相互合作的bean,這意味著容器不需要<constructor-arg>和<property>配置,能通過Bean工廠自動處理bean之間的協作。

33. 解釋不同方式的自動裝配 。

有五種自動裝配的方式,可以用來指導Spring容器用自動裝配方式來進行依賴注入。

  • no:預設的方式是不進行自動裝配,通過顯式設定ref 屬性來進行裝配。
  • byName:通過引數名 自動裝配,Spring容器在配置檔案中發現bean的autowire屬性被設定成byname,之後容器試圖匹配、裝配和該bean的屬性具有相同名字的bean。
  • byType::通過引數型別自動裝配,Spring容器在配置檔案中發現bean的autowire屬性被設定成byType,之後容器試圖匹配、裝配和該bean的屬性具有相同型別的bean。如果有多個bean符合條件,則丟擲錯誤。
  • constructor:這個方式類似於byType, 但是要提供給構造器引數,如果沒有確定的帶引數的構造器引數型別,將會丟擲異常。
  • autodetect:首先嚐試使用constructor來自動裝配,如果無法工作,則使用byType方式。

34.自動裝配有哪些侷限性 ?

自動裝配的侷限性是:

  • 重寫: 你仍需用 <constructor-arg>和 <property> 配置來定義依賴,意味著總要重寫自動裝配。
  • 基本資料型別:你不能自動裝配簡單的屬性,如基本資料型別,String字串,和類。
  • 模糊特性:自動裝配不如顯式裝配精確,如果有可能,建議使用顯式裝配。

35. 你可以在Spring中注入一個null 和一個空字串嗎?

可以。

Spring註解

36. 什麼是基於Java的Spring註解配置? 給一些註解的例子.

基於Java的配置,允許你在少量的Java註解的幫助下,進行你的大部分Spring配置而非通過XML檔案。

以@Configuration 註解為例,它用來標記類可以當做一個bean的定義,被Spring IOC容器使用。另一個例子是@Bean註解,它表示此方法將要返回一個物件,作為一個bean註冊進Spring應用上下文。

37. 什麼是基於註解的容器配置?

相對於XML檔案,註解型的配置依賴於通過位元組碼元資料裝配元件,而非尖括號的宣告。

開發者通過在相應的類,方法或屬性上使用註解的方式,直接元件類中進行配置,而不是使用xml表述bean的裝配關係。

38. 怎樣開啟註解裝配?

註解裝配在預設情況下是不開啟的,為了使用註解裝配,我們必須在Spring配置檔案中配置 <context:annotation-config/>元素。

39. @Required 註解

這個註解表明bean的屬性必須在配置的時候設定,通過一個bean定義的顯式的屬性值或通過自動裝配,若@Required註解的bean屬性未被設定,容器將丟擲BeanInitializationException。

40. @Autowired 註解

@Autowired 註解提供了更細粒度的控制,包括在何處以及如何完成自動裝配。它的用法和@Required一樣,修飾setter方法、構造器、屬性或者具有任意名稱和/或多個引數的PN方法。

41. @Qualifier 註解

當有多個相同型別的bean卻只有一個需要自動裝配時,將@Qualifier 註解和@Autowire 註解結合使用以消除這種混淆,指定需要裝配的確切的bean。

Spring資料訪問

42.在Spring框架中如何更有效地使用JDBC?

使用SpringJDBC 框架,資源管理和錯誤處理的代價都會被減輕。所以開發者只需寫statements 和 queries從資料存取資料,JDBC也可以在Spring框架提供的模板類的幫助下更有效地被使用,這個模板叫JdbcTemplate (例子見這裡here

43. JdbcTemplate

JdbcTemplate 類提供了很多便利的方法解決諸如把資料庫資料轉變成基本資料型別或物件,執行寫好的或可呼叫的資料庫操作語句,提供自定義的資料錯誤處理。

44. Spring對DAO的支援

Spring對資料訪問物件(DAO)的支援旨在簡化它和資料訪問技術如JDBC,Hibernate or JDO 結合使用。這使我們可以方便切換持久層。編碼時也不用擔心會捕獲每種技術特有的異常。

45. 使用Spring通過什麼方式訪問Hibernate?

在Spring中有兩種方式訪問Hibernate:

  • 控制反轉 Hibernate Template和 Callback。
  • 繼承 HibernateDAOSupport提供一個AOP 攔截器。

46. Spring支援的ORM

Spring支援以下ORM:

  • Hibernate
  • iBatis
  • JPA (Java Persistence API)
  • TopLink
  • JDO (Java Data Objects)
  • OJB

47.如何通過HibernateDaoSupport將Spring和Hibernate結合起來?

用Spring的 SessionFactory 呼叫 LocalSessionFactory。整合過程分三步:

  • 配置the Hibernate SessionFactory。
  • 繼承HibernateDaoSupport實現一個DAO。
  • 在AOP支援的事務中裝配。

48. Spring支援的事務管理型別

Spring支援兩種型別的事務管理:

  • 程式設計式事務管理:這意味你通過程式設計的方式管理事務,給你帶來極大的靈活性,但是難維護。
  • 宣告式事務管理:這意味著你可以將業務程式碼和事務管理分離,你只需用註解和XML配置來管理事務。

49. Spring框架的事務管理有哪些優點?

  • 它為不同的事務API 如 JTA,JDBC,Hibernate,JPA 和JDO,提供一個不變的程式設計模式。
  • 它為程式設計式事務管理提供了一套簡單的API而不是一些複雜的事務API如
  • 它支援宣告式事務管理。
  • 它和Spring各種資料訪問抽象層很好得整合。

50. 你更傾向用那種事務管理型別?

大多數Spring框架的使用者選擇宣告式事務管理,因為它對應用程式碼的影響最小,因此更符合一個無侵入的輕量級容器的思想。宣告式事務管理要優於程式設計式事務管理,雖然比程式設計式事務管理(這種方式允許你通過程式碼控制事務)少了一點靈活性。

Spring面向切面程式設計(AOP)

51. 解釋AOP

面向切面的程式設計,或AOP, 是一種程式設計技術,允許程式模組化橫向切割關注點,或橫切典型的責任劃分,如日誌和事務管理。

52. Aspect 切面

AOP核心就是切面,它將多個類的通用行為封裝成可重用的模組,該模組含有一組API提供橫切功能。比如,一個日誌模組可以被稱作日誌的AOP切面。根據需求的不同,一個應用程式可以有若干切面。在Spring AOP中,切面通過帶有@Aspect註解的類實現。

52. 在Spring AOP 中,關注點和橫切關注的區別是什麼?

關注點是應用中一個模組的行為,一個關注點可能會被定義成一個我們想實現的一個功能。

橫切關注點是一個關注點,此關注點是整個應用都會使用的功能,並影響整個應用,比如日誌,安全和資料傳輸,幾乎應用的每個模組都需要的功能。因此這些都屬於橫切關注點。

54. 連線點

連線點代表一個應用程式的某個位置,在這個位置我們可以插入一個AOP切面,它實際上是個應用程式執行Spring AOP的位置。

55. 通知

通知是個在方法執行前或執行後要做的動作,實際上是程式執行時要通過SpringAOP框架觸發的程式碼段。

Spring切面可以應用五種型別的通知:

  • before:前置通知,在一個方法執行前被呼叫。
  • after: 在方法執行之後呼叫的通知,無論方法執行是否成功。
  • after-returning: 僅當方法成功完成後執行的通知。
  • after-throwing: 在方法丟擲異常退出時執行的通知。
  • around: 在方法執行之前和之後呼叫的通知。

56. 切點

切入點是一個或一組連線點,通知將在這些位置執行。可以通過表示式或匹配的方式指明切入點。

57. 什麼是引入?

引入允許我們在已存在的類中增加新的方法和屬性。

58. 什麼是目標物件?

被一個或者多個切面所通知的物件。它通常是一個代理物件。也指被通知(advised)物件。

59. 什麼是代理?

代理是通知目標物件後建立的物件。從客戶端的角度看,代理物件和目標物件是一樣的。

60. 有幾種不同型別的自動代理?

BeanNameAutoProxyCreator

DefaultAdvisorAutoProxyCreator

Metadata autoproxying

61. 什麼是織入。什麼是織入應用的不同點?

織入是將切面和到其他應用型別或物件連線或建立一個被通知物件的過程。

織入可以在編譯時,載入時,或執行時完成。

62. 解釋基於XML Schema方式的切面實現。

在這種情況下,切面由常規類以及基於XML的配置實現。

63. 解釋基於註解的切面實現

在這種情況下(基於@AspectJ的實現),涉及到的切面宣告的風格與帶有java5標註的普通java類一致。

Spring 的MVC

64. 什麼是Spring的MVC框架?

Spring 配備構建Web 應用的全功能MVC框架。Spring可以很便捷地和其他MVC框架整合,如Struts,Spring 的MVC框架用控制反轉把業務物件和控制邏輯清晰地隔離。它也允許以宣告的方式把請求引數和業務物件繫結。

65. DispatcherServlet

Spring的MVC框架是圍繞DispatcherServlet來設計的,它用來處理所有的HTTP請求和響應。

66. WebApplicationContext

WebApplicationContext 繼承了ApplicationContext 並增加了一些WEB應用必備的特有功能,它不同於一般的ApplicationContext ,因為它能處理主題,並找到被關聯的servlet。

67. 什麼是Spring MVC框架的控制器?

控制器提供一個訪問應用程式的行為,此行為通常通過服務介面實現。控制器解析使用者輸入並將其轉換為一個由檢視呈現給使用者的模型。Spring用一個非常抽象的方式實現了一個控制層,允許使用者建立多種用途的控制器。

68. @Controller 註解

該註解表明該類扮演控制器的角色,Spring不需要你繼承任何其他控制器基類或引用Servlet API。

69. @RequestMapping 註解

該註解是用來對映一個URL到一個類或一個特定的方處理法上。