經過上面的 @EnableAutoConfiguration 註解就能根據指定的依賴,自動進行配置。但若是你想關閉某一項自動配置,就須要使用 @SpringBootApplication 下的 exclude 參數來設置。好比,我想關閉 DataSource,代碼具體以下:php
1@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})html
能知足企業定製 logo 或項目啓動圖案。好比,能夠藉助以下幾個網站來生成:java
1http://patorjk.com/software/taag
2http://www.network-science.de/ascii/
3http://www.kammerl.de/ascii/AsciiSignature.php
生成以後,直接將複製好的圖案,放到新建的 banner.txt 文件中。運行程序以後,具體顯示效果以下:web
通常使用 application.properties 或者 application.yml 文件來看成全局配置文件。它能被添加在下面幾個目錄下,區別是加載的順序是不一樣的,具體以下:算法
1項目根目錄的 /config 目錄下
2項目根目錄下
3類路徑的 /config 目錄下
4類路徑下
好比,能夠在 application.properties 配置文件中,設置端口、請求後綴等內容。具體的配置參數能夠參考官網文檔第 10 章 Appendices:https://docs.spring.io/spring-boot/docs/2.2.2.RELEASE/reference/htmlsingle/#common-application-propertiesspring
在 Spring Boot 應用中,能夠內置 Tomcat、Netty、Jetty 等容器。tomcat
1)配置 Tomcat安全
若是添加了 spring-boot-starter-web 依賴,則項目會默認使用 Tomcat 做爲 Web 容器。服務器
針對 Tomcat 能夠添加一些配置,具體配置以下:session
1# 端口
2server.port=80
3# 錯誤跳轉路徑
4server.error.path
5# session 失效時間
6server.servlet.session.timeout
7# 項目名稱
8server.servlet.context-path
9# 編碼,通常 utf-8
10server.tomcat.uri-encoding=utf-8
11# ...
2)配置 Jetty
在 Spring Boot 應用中嵌入 Jetty 的配置很簡單,把 spring-boot-starter-web 中的 Tomcat 改爲 Jetty 便可,具體配置以下:
1
2<dependency>
3 <groupId>org.springframework.boot</groupId>
4 <artifactId>spring-boot-starter-web</artifactId>
5 <exclusions>
6 <exclusion>
7 <groupId>org.springframework.boot</groupId>
8 <artifactId>spring-boot-starter-tomcat</artifactId>
9 </exclusion>
10 </exclusions>
11</dependency>
12
13
14<dependency>
15 <groupId>org.springframework.boot</groupId>
16 <artifactId>spring-boot-starter-jetty</artifactId>
17</dependency>
3)配置 Undertow
Undertow 是紅帽公司開發的一款基於 NIO 的高性能 Web 嵌入式服務器,擁有很是好的性能。配置方式具體以下:
1
2<dependency>
3 <groupId>org.springframework.boot</groupId>
4 <artifactId>spring-boot-starter-web</artifactId>
5 <exclusions>
6 <exclusion>
7 <groupId>org.springframework.boot</groupId>
8 <artifactId>spring-boot-starter-tomcat</artifactId>
9 </exclusion>
10 </exclusions>
11</dependency>
12
13
14<dependency>
15 <groupId>org.springframework.boot</groupId>
16 <artifactId>spring-boot-starter-undertow</artifactId>
17</dependency>
使用 JDK 提供的 keytool 工具,能夠生成一個數字證書,具體命令以下:
1keytool -genkey -alias httpskey -keyalg RSA -keysize 2048 -keystore hello.p12 -validity 365
-genkey 表示建立一個密鑰
-alias httpskey 設置密鑰的別名
-keyalg RSA 表示使用的加密算法是 RSA
-keysize 2048 設置密鑰的長度
-keystore hello.p12 設置密鑰存放位置
-validity 365 設置密鑰的有效時間
而後在 application.properties 文件中編輯,具體配置以下:
1server.ssl.key-store=hello.p12
2server.ssl.key-alias=httpskey
3server.ssl.key-store-password=123456
前面也說過,咱們的配置文件可使用 properties 配置和 yaml 配置,項目啓動後,它們都會被加載到 Spring 的環境中,若是你要用配置信息的話,直接使用 @Value 註解便可。
但數據注入到屬性中,須要注意安全。Spring Boot 使用類型安全配置屬性,即便在數據量很是龐大的狀況下,將配置文件中的數據注入到 Bean 裏也是很方便的。
1user.name=翠花
2user.age=18
3user.address=北京
添加對應的 Bean 類,使用 @ConfigurationProperties 註解來使用配置,經過 prefix 屬性來描述要加載的配置文件的前綴,具體以下:
1@Componentbr/>2@ConfigurationProperties(prefix="user")
3public class User {
4 private String name;
5 private Integer age;
6 private String address;
7 // get 和 set 方法...
8}
YAML 是專門用來寫配置文件的語言,很是簡潔、強大,相似 JSON。它可用來替換 application.properties 文件。YAML 主要是由 spring-boot-starter-web 依賴模塊中的 snakeyaml 依賴進行解析。但它不能使用 @propertySource 註解加載 YAML 文件,不然還要使用 Properties 配置。
舉個小案例,具體寫法以下:
1server:
2 port:80
3 servlet:
4 context-path:/hello
5 tomcat:
6 uri-encoding:utf-8
還能夠自定義配置,具體寫法以下:
1user:
2 name:翠花
3 age:18
對應的代碼,跟前面的 User 類同樣,具體源碼以下:
1@Componentbr/>2@ConfigurationProperties(prefix="user")
3public class User {
4 private String name;
5 private Integer age;
6 // get 和 set 方法...
7}
還能設置成集合的樣式,集合中是單個值,具體寫法以下:
1user:
2 name:翠花
3 age:18
4 aihao:
5 - 燙頭
6 - 捏腳
7 - Reading
對應的代碼,具體源碼以下:
1@Componentbr/>2@ConfigurationProperties(prefix="user")
3public class User {
4 private String name;
5 private Integer age;
6 private List<String> aihao;
7 // get 和 set 方法...
8}
也能先設置成集合的樣式,但集合中是對象,具體寫法以下:
1shop:
2 users:
3 - name:翠花
4 age:18
5 aihao:
6 - 燙頭
7 - 捏腳
8 - Reading
9 - name:小強
10 age:18
11 aihao:
12 - 燙頭
13 - 捏腳
14 - Reading
對應的代碼,具體源碼以下:
1@Componentbr/>2@ConfigurationProperties(prefix="shop")
3public class Users {
4 private List<User> users;
5 // get 和 set 方法...
6}
1public class User {
2 private String name;
3 private Integer age;
4 private List<String> aihao;
5 // get 和 set 方法...
6}
若是咱們在項目中,須要頻繁在開發環境、測試環境和生產環境中更改大量的配置,會讓你懷疑人生,因此咱們使用 @Profile 註解來更加簡潔進行處理。
具體的命名規則:application-{xxx}.properties,這樣就能在不一樣環境下進行區別配置信息。具體使用步驟以下:
第一步,添加配置文件
在 resources 目錄中,建立 application-dev.properties 和 application-prod.properties 文件,表明開發和生產環境中的配置。
1# 開發環境
2server.port=8080
1# 生產環境
2server.port=80
第二步,指定對應模式
1)在 application.properties 中指定
1# 開發時用 dev,生產時用 prod
2spring.profiles.active=dev
2)在啓動類 main 方法中指定
1SpringApplicationBuilder builder = new SpringApplicationBuilder(SpringBootApp.class);
2
3builder.application().setAdditionalProfiles("prod");
4
5builder.run(args);
3)也能夠在項目啓動時配置
在咱們將項目打成 jar 文件再啓動,具體的操做命令以下:
1java -jar springdemo-xxx.jar --spring.profiles.active=prod來源於:奈學開發者社區-江帥帥