Spring Boot1:介紹和創建項目

1.spring Boot官網:Spring Boot

2.spring Boot介紹:

使用Spring Boot可以讓我們快速創建一個基於Spring的項目,而讓這個Spring項目跑起來我們只需要很少的配置

3.spring Boot優點:

(1)獨立運行的Spring項目

 Spring Boot可以以jar包的形式來運行,運行一個Spring Boot項目我們只需要通過java -jar xx.jar類運行。非常方便。

(2)內嵌Servlet容器

Spring Boot可以內嵌Tomcat,這樣我們無需以war包的形式部署項目。

(3)提供starter簡化Maven或者gradle配置

使用Spring或者SpringMVC我們需要添加大量的依賴,而這些依賴很多都是固定的,這裏Spring Boot 通過starter能夠幫助我們簡化Maven或者gradle配置。

(4)自動配置Spring 

(5)準生產的應用監控 

(6)無代碼生成和xml配置

4.quick start

以IntelliJ IDEA爲例,創建一個springboot項目

|(1)首先創建一個項目,創建時選擇Spring Initializr,然後Next,如下圖:


(2)填寫項目信息,如下圖:


(3)填寫項目使用到的技術,上面的Spring Boot版本建議選擇最新的穩定版,下面勾選上Web就可以了,如下圖:


(4)填寫工程名字點擊finish:


注意:第一次創建時系統會去下載需要的依賴等,耗時稍長,以後每次都會很快創建好。 

5.運行項目

在項目創建成功之後,在項目的根目錄下會有一個artifactId+Application命名規則的入口類,如下圖: 


就是這個DemoApplication類,這是我們整個項目的入口類,這個類有一個@SpringBootApplication註解,這是整個Spring Boot的核心註解,它的目的就是開啓Spring Boot的自動配置。OK,那麼我在這個類上再添加一個@RestController註解,使之變爲一個Controller,然後裏邊提供一個地址轉換方法,如下:

package com.example.demo;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@RestController
@SpringBootApplication
public class DemoApplication {

	public static void main(String[] args) {
		SpringApplication.run(DemoApplication.class, args);
	}
	@RequestMapping(value="/",produces="text/plain;charset=UTF-8")
	public String index(){
		return "Hello String Boot";
	}
}

然後點擊項目啓動按鈕運行,在IntelliJ中就是這個按鈕: 


啓動成功之後,在瀏覽器中訪問,如下: 


6.詳解

(1)入口類

新建一個Project系統都會幫我們創建一個名爲artifactId+Application的入口類,這個類中有一個main方法,這個main方法就是一個標準的Java應用程序的入口方法

(2)@SpringBootApplication註解 源碼

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(
    excludeFilters = {@Filter(
    type = FilterType.CUSTOM,
    classes = {TypeExcludeFilter.class}
)}
)
public @interface SpringBootApplication {

}

它組合了@SpringBootConfiguration、@EnableAutoConfiguration以及@ComponentScan,我們在開發的過程中如果不使用@SpringBootApplication,則可以組合使用這三個註解。這三個註解中,@SpringBootConfiguration實際上就是我們前面幾篇博客提到的@Configuration註解,表明這個類是一個配置類,@EnableAutoConfiguration則表示讓Spring Boot根據類路徑中的jar包依賴爲當前項目進行自動配置,最後一個@ComponentScan的作用我也不贅述了,唯一要注意的是如果我們使用了@SpringBootApplication註解的話,系統會去入口類的同級包以及下級包中去掃描實體類,因此我們建議入口類的位置在groupId+arctifactID組合的包名下。

(3)關閉特定的自動配置

@ComponentScan註解是有一個過濾器的,如果我們只想要@SpringBootApplication去掃描特定的類而不是全部類,那麼就可以關閉自動配置,如下:

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)

7.banner

我們在啓動Spring Boot項目的時候,在控制檯會默認輸出一個啓動圖案,如下: 

這個圖案如果你需要的話是可以自己修改的,修改方式很簡單:

(1)在src/main/resources下新建一個banner.txt文檔 

(2)通過http://patorjk.com/software/taag網站生成需要的字符,將字符拷貝到步驟1所創建的txt文檔中,比如我這裏爲Hello Sang!生成字符,如下:


(3)點擊左下角的選擇和拷貝按鈕,將這個字符拷貝到txt文檔中,然後再啓動項目,這個時候控制檯輸出的文本就會自動改變

(4)關閉Banner需要我們稍微修改一下main方法中的代碼,如下:

public static void main(String[] args) {
        SpringApplicationBuilder builder = new SpringApplicationBuilder(Test19SpringBoot2Application.class);
        //修改Banner的模式爲OFF
        builder.bannerMode(Banner.Mode.OFF).run(args);
    }

如此修改之後當我們再次啓動Project的時候就看不到Banner了。

8.Spring Boot的配置文件

Spring Boot使用一個全局的配置文件application.properties或者application.yml,配置文件放在src/main/resources目錄下。properties是我們常見的一種配置文件,Spring Boot不僅支持properties這種類型的配置文件,也支持yaml語言的配置文件,我這裏以properties類型的配置文件爲例來看幾個案例

(1)修改Tomcat默認端口和默認訪問路徑,Tomcat默認端口是8080,我將之改爲8081,默認訪問路徑是http://localhost:8080,我將之改爲http://localhost:8081/helloboot,我們來看看這兩個需求要怎麼樣通過簡單的配置來實現。 

很簡單,在application.properties文件中添加如下代碼:

server.context-path=/helloboot
server.port=8081
然後再啓動Project,在瀏覽器中就得這樣來訪問了: 



(2)常規屬性配置

使用了Spring Boot,這項工作將會變得更加簡單,我們只需要在application.properties中定義屬性,然後在代碼中直接使用@Value注入即可。 

product.author=zoe
product.name=ylly
我這裏專門設置了中文,因爲中文不做特殊處理會亂碼,處理方式爲繼續在application.properties中添加如下代碼:
server.tomcat.uri-encoding=UTF-8
spring.http.encoding.charset=UTF-8
spring.http.encoding.enabled=true
spring.http.encoding.force=true
spring.messages.encoding=UTF-8
然後 在IntelliJ IDEA中依次點擊File -> Settings -> Editor -> File Encodings 
將Properties Files (*.properties)下的Default encoding for properties files設置爲UTF-8,將Transparent native-to-ascii conversion前的勾選上。(可參考Springboot 之 解決IDEA讀取properties配置文件的中文亂碼問題)

然後在變量中通過@Value直接注入就行了,如下:

    @Value(value = "${product.author}")
    private String pAuthor;
    @Value("${product.name}")
    private String pName;

修改index方法,使之返回這些值:

@RequestMapping(value = "/",produces = "text/plain;charset=UTF-8")
    String index(){
        return "Hello Spring Boot! The pName is "+pName+";and product Author is "+pAuthor;
    }

然後在瀏覽器中訪問,結果如下: 

(9)類型安全的配置

上述方式我們在實際項目中使用的時候工作量略大,因爲每個項目要注入的變量的值太多了,這種時候我們可以使用基於類型安全的配置方式,就是將properties屬性和一個Bean關聯在一起,這樣使用起來會更加方便。下來看看這種方式怎麼實現。

a.在src/main/resources文件夾下創建文件product.properties

文件內容如下

product.author=zoe
product.name=ylly發送

b.創建product Bean,並注入properties文件中的值,代碼如下:

Component
@ConfigurationProperties(prefix = "product",locations = "classpath:product.properties")
public class ProductBean {
    private String name;
    private String author;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }
}

可能會報錯

spring boot Configuration Annotation Proessor not found in classpath

解決方法:解決

c.添加路徑映射

在Controller中添加如下代碼注入Bean

@Autowired
private ProductBean pBean;

添加路徑映射:

@RequestMapping("/product")
    public String book() {
        return "Hello Spring Boot! The pName is "+pBean.getName()+";and pAuthor is "+pBean.getAuthor();
    }

瀏覽器訪問如下:

(10)日誌配置

默認情況下Spring Boot使用Logback作爲日誌框架,也就是我們前面幾篇博客中用到的打印日誌方式,當然如果有需要我們可以手動配置日誌級別以及日誌輸出位置,相比於我們在Spring容器中寫的日誌輸出代碼,這裏的配置很簡單,只需要在application.properties中添加如下代碼:

logging.file=/home/sang/workspace/log.log
logging.level.org.springframework.web=debug

上面表示配置日誌輸出位置,下面配置日誌級別。

(11)Profile配置問題

全局Profile配置我們使用application-{profile}.properties來定義,然後在application.properties中通過spring.profiles.active來指定使用哪個Profile。如下例:

a.在src/main/resources文件夾下定義不同環境下的Profile配置文件,文件名分別爲application-prod.properties和application-dev.properties,這兩個前者表示生產環境下的配置,後者表示開發環境下的配置,如下:

application-prod.properties:

server.port=8081

application-dev.properties:

server.port=8080

然後在application.properties中進行簡單配置,如下:

spring.profiles.active=dev

這個表示使用開發環境下的配置。然後運行項目,我們得通過8080端口纔可以訪問,

產品環境下把spring.profiles.active=dev改成spring.profiles.active=prod 需要通過8081訪問

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章