前面的鋪墊文章已經(jīng)連著寫了六篇了,主要是介紹了spring和springmvc框架,小伙伴們?cè)趯W(xué)習(xí)的過程中大概也發(fā)現(xiàn)了這兩個(gè)框架需要我們手動(dòng)配置的地方非常多,不過做javaee開發(fā)的小伙伴們肯定也聽說過“約定大于配置”這樣一句話,就是說系統(tǒng),類庫(kù),框架應(yīng)該假定合理的默認(rèn)值,而非要求提供不必要的配置,可是使用spring或者springmvc的話依然有許多這樣的東西需要我們進(jìn)行配置,這樣不僅徒增工作量而且在跨平臺(tái)部署時(shí)容易出問題。ok,由于這些已經(jīng)存在的問題,spring boot應(yīng)運(yùn)而生,使用spring boot可以讓我們快速創(chuàng)建一個(gè)基于spring的項(xiàng)目,而讓這個(gè)spring項(xiàng)目跑起來我們只需要很少的配置就可以了。spring boot主要有如下核心功能:
1.獨(dú)立運(yùn)行的spring項(xiàng)目
spring boot可以以jar包的形式來運(yùn)行,運(yùn)行一個(gè)spring boot項(xiàng)目我們只需要通過java -jar xx.jar類運(yùn)行。非常方便。
2.內(nèi)嵌servlet容器
spring boot可以內(nèi)嵌tomcat,這樣我們無需以war包的形式部署項(xiàng)目。
3.提供starter簡(jiǎn)化maven配置
使用spring或者springmvc我們需要添加大量的依賴,而這些依賴很多都是固定的,這里spring boot 通過starter能夠幫助我們簡(jiǎn)化maven配置。
4.自動(dòng)配置spring
5.準(zhǔn)生產(chǎn)的應(yīng)用監(jiān)控
6.無代碼生成和xml配置
ok,關(guān)于springboot更詳細(xì)的優(yōu)缺點(diǎn)小伙伴們也可以自行搜索,我這里不再羅列,我們還是來看看代碼。
項(xiàng)目創(chuàng)建
初次接觸,我們先來看看如何創(chuàng)建一個(gè)spring boot項(xiàng)目,這里以intellij idea為例,其他的ide工具小伙伴們自行搜索創(chuàng)建方式:
首先創(chuàng)建一個(gè)項(xiàng)目,創(chuàng)建時(shí)選擇spring initializr,然后next,如下圖:
填寫項(xiàng)目信息,如下圖:
填寫項(xiàng)目使用到的技術(shù),上面的spring boot版本建議選擇最新的穩(wěn)定版,下面勾選上web就可以了,如下圖:
最后一步,填寫工程名字點(diǎn)擊finish:
ok,第一次創(chuàng)建時(shí)系統(tǒng)會(huì)去下載需要的依賴等,耗時(shí)稍長(zhǎng),以后每次都會(huì)很快創(chuàng)建好。
ok,項(xiàng)目創(chuàng)建成功之后接下來我們來看看這個(gè)東西要怎么樣去運(yùn)行。首先我們看到在項(xiàng)目創(chuàng)建成功之后,在項(xiàng)目的根目錄下會(huì)有一個(gè)artifactid+application命名規(guī)則的入口類,如下圖:
就是這個(gè)test19springboot2application類,這是我們整個(gè)項(xiàng)目的入口類,這個(gè)類有一個(gè)@springbootapplication注解,這是整個(gè)spring boot的核心注解,它的目的就是開啟spring boot的自動(dòng)配置。ok,那么我在這個(gè)類上再添加一個(gè)@restcontroller注解,使之變?yōu)橐粋€(gè)controller,然后里邊提供一個(gè)地址轉(zhuǎn)換方法,如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
|
@restcontroller @springbootapplication public class test19springboot2application { public static void main(string[] args) { springapplication.run(test19springboot2application. class , args); } @requestmapping (value = "/" ,produces = "text/plain;charset=utf-8" ) string index(){ return "hello spring boot!" ; } } |
然后點(diǎn)擊項(xiàng)目啟動(dòng)按鈕運(yùn)行,在intellij中就是這個(gè)按鈕:
啟動(dòng)成功之后我們就可以直接在瀏覽器中訪問了,如下:
ok,至此,我們一個(gè)簡(jiǎn)單的spring boot工程已經(jīng)創(chuàng)建出來了,并且成功的從瀏覽器中訪問到了,但是為什么它最終會(huì)跑起來呢?想必小伙伴們還有許多疑問,我們來分析下。
入口類和@springbootapplication注解
上文說過,我們新建一個(gè)project系統(tǒng)都會(huì)幫我們創(chuàng)建一個(gè)名為artifactid+application的入口類,這個(gè)類中有一個(gè)main方法,這個(gè)main方法就是一個(gè)標(biāo)準(zhǔn)的java應(yīng)用程序的入口方法。而這里的@springbootapplication則是一個(gè)組合注解,我們可以看看它的源碼:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
@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,我們?cè)陂_發(fā)的過程中如果不使用@springbootapplication,則可以組合使用這三個(gè)注解。這三個(gè)注解中,@springbootconfiguration實(shí)際上就是我們前面幾篇博客提到的@configuration注解,表明這個(gè)類是一個(gè)配置類,@enableautoconfiguration則表示讓spring boot根據(jù)類路徑中的jar包依賴為當(dāng)前項(xiàng)目進(jìn)行自動(dòng)配置,最后一個(gè)@componentscan的作用我也不贅述了,唯一要注意的是如果我們使用了@springbootapplication注解的話,系統(tǒng)會(huì)去入口類的同級(jí)包以及下級(jí)包中去掃描實(shí)體類,因此我們建議入口類的位置在groupid+arctifactid組合的包名下。
關(guān)閉特定的自動(dòng)配置
在上面一小節(jié)中我們看到@componentscan注解是有一個(gè)過濾器的,如果我們只想要@springbootapplication去掃描特定的類而不是全部類,那么就可以關(guān)閉自動(dòng)配置,如下:
1
|
@springbootapplication (exclude = datasourceautoconfiguration. class ) |
定制banner
修改banner
我們?cè)趩?dòng)spring boot項(xiàng)目的時(shí)候,在控制臺(tái)會(huì)默認(rèn)輸出一個(gè)啟動(dòng)圖案,如下:
當(dāng)然,這個(gè)圖案如果你需要的話是可以自己修改的,修改方式很簡(jiǎn)單:
1.在src/main/resources下新建一個(gè)banner.txt文檔
2.通過網(wǎng)站生成需要的字符,將字符拷貝到步驟1所創(chuàng)建的txt文檔中,比如我這里為hello sang!生成字符,如下:
點(diǎn)擊左下角的選擇和拷貝按鈕,將這個(gè)字符拷貝到txt文檔中,然后再啟動(dòng)項(xiàng)目,這個(gè)時(shí)候控制臺(tái)輸出的文本就會(huì)自動(dòng)改變,如下:
關(guān)閉banner
可以修改當(dāng)然也可以關(guān)閉,關(guān)閉banner需要我們稍微修改一下main方法中的代碼,如下:
1
2
3
4
5
|
public static void main(string[] args) { springapplicationbuilder builder = new springapplicationbuilder(test19springboot2application. class ); //修改banner的模式為off builder.bannermode(banner.mode.off).run(args); } |
ok,如此修改之后當(dāng)我們?cè)俅螁?dòng)project的時(shí)候就看不到banner了。
spring boot的配置文件
spring boot使用一個(gè)全局的配置文件application.properties或者application.yml,配置文件放在src/main/resources目錄下。properties是我們常見的一種配置文件,spring boot不僅支持properties這種類型的配置文件,也支持yaml語言的配置文件,我這里以properties類型的配置文件為例來看幾個(gè)案例。
1.修改tomcat默認(rèn)端口和默認(rèn)訪問路徑
tomcat默認(rèn)端口是8080,我將之改為8081,默認(rèn)訪問路徑是http://localhost:8080,我將之改為http://localhost:8081/helloboot,我們來看看這兩個(gè)需求要怎么樣通過簡(jiǎn)單的配置來實(shí)現(xiàn)。
很簡(jiǎn)單,在application.properties文件中添加如下代碼:
1
2
|
server.context-path=/helloboot server.port= 8081 |
然后再啟動(dòng)project,在瀏覽器中就得這樣來訪問了:
常規(guī)屬性配置
在前面的博客中我們介紹了如何在使用spring容器框架下注入properties文件里的值。如果我們使用了spring boot,這項(xiàng)工作將會(huì)變得更加簡(jiǎn)單,我們只需要在application.properties中定義屬性,然后在代碼中直接使用@value注入即可。
如下:
1
2
3
|
book.author=羅貫中 book.name=三國(guó)演義 book.pinyin=sanguoyanyi |
我這里專門設(shè)置了中文,因?yàn)橹形牟蛔鎏厥馓幚頃?huì)亂碼,處理方式為繼續(xù)在application.properties中添加如下代碼:
1
2
3
4
5
|
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中依次點(diǎn)擊file -> settings -> editor -> file encodings
將properties files (*.properties)下的default encoding for properties files設(shè)置為utf-8,將transparent native-to-ascii conversion前的勾選上。
然后在變量中通過@value直接注入就行了,如下:
1
2
3
4
5
6
|
@value (value = "${book.author}" ) private string bookauthor; @value ( "${book.name}" ) private string bookname; @value ( "${book.pinyin}" ) private string bookpinyin; |
修改index方法,使之返回這些值:
1
2
3
4
|
@requestmapping (value = "/" ,produces = "text/plain;charset=utf-8" ) string index(){ return "hello spring boot! the bookname is " +bookname+ ";and book author is " +bookauthor+ ";and book pinyin is " +bookpinyin; } |
然后在瀏覽器中訪問,結(jié)果如下:
很簡(jiǎn)單吧。
類型安全的配置
剛剛說的這種方式我們?cè)趯?shí)際項(xiàng)目中使用的時(shí)候工作量略大,因?yàn)槊總€(gè)項(xiàng)目要注入的變量的值太多了,這種時(shí)候我們可以使用基于類型安全的配置方式,就是將properties屬性和一個(gè)bean關(guān)聯(lián)在一起,這樣使用起來會(huì)更加方便。我么來看看這種方式怎么實(shí)現(xiàn)。
1.在src/main/resources文件夾下創(chuàng)建文件book.properties
文件內(nèi)容如下:
1
2
3
|
book.name=紅樓夢(mèng) book.author=曹雪芹 book.price= 28 |
2.創(chuàng)建book bean,并注入properties文件中的值
代碼如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
@component @configurationproperties (prefix = "book" ,locations = "classpath:book.properties" ) public class bookbean { private string name; private string author; private string price; 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; } public string getprice() { return price; } public void setprice(string price) { this .price = price; } } |
prefix是指前綴,location指定要注入文件的位置。
3.添加路徑映射
在controller中添加如下代碼注入bean:
1
2
|
@autowired private bookbean bookbean; |
添加路徑映射:
1
2
3
4
|
@requestmapping ( "/book" ) public string book() { return "hello spring boot! the bookname is " +bookbean.getname()+ ";and book author is " +bookbean.getauthor()+ ";and book price is " +bookbean.getprice(); } |
運(yùn)行效果如下:
日志配置
默認(rèn)情況下spring boot使用logback作為日志框架,也就是我們前面幾篇博客中用到的打印日志方式,當(dāng)然如果有需要我們可以手動(dòng)配置日志級(jí)別以及日志輸出位置,相比于我們?cè)趕pring容器中寫的日志輸出代碼,這里的配置簡(jiǎn)直就是小兒科了,只需要在application.properties中添加如下代碼:
1
2
|
logging.file=/home/sang/workspace/log.log logging.level.org.springframework.web=debug |
上面表示配置日志輸出位置,下面配置日志級(jí)別。
profile配置問題
在 spring常用配置 這篇文章中,我們已經(jīng)介紹了profile的作用,已經(jīng)如何在spring框架下使用profile,但是當(dāng)時(shí)小伙伴們看到了還是稍微有點(diǎn)麻煩,在spring boot 中系統(tǒng)提供了更為簡(jiǎn)潔的方式。全局profile配置我們使用application-{profile}.properties來定義,然后在application.properties中通過spring.profiles.active來指定使用哪個(gè)profile。ok,那么接下來我們來看一個(gè)簡(jiǎn)單的案例。
1.在src/main/resources文件夾下定義不同環(huán)境下的profile配置文件,文件名分別為application-prod.properties和application-dev.properties,這兩個(gè)前者表示生產(chǎn)環(huán)境下的配置,后者表示開發(fā)環(huán)境下的配置,如下:
application-prod.properties:
1
|
server.port= 8081 |
application-dev.properties:
1
|
server.port= 8080 |
然后在application.properties中進(jìn)行簡(jiǎn)單配置,如下:
1
|
spring.profiles.active=dev |
這個(gè)表示使用開發(fā)環(huán)境下的配置。然后運(yùn)行項(xiàng)目,我們得通過8080端口才可以訪問:
如果想換為生產(chǎn)環(huán)境,只需要把spring.profiles.active=dev改為spring.profiles.active=prod即可,當(dāng)然訪問端口這是也變?yōu)?081了,如下:
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持服務(wù)器之家。
原文鏈接:http://blog.csdn.net/u012702547/article/details/53740047