本篇內容介紹了“怎么使用Spring Boot”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
通過上面的 @EnableAutoConfiguration 注解就能根據指定的依賴,自動進行配置。但如果你想關閉某一項自動配置,就需要使用 @SpringBootApplication 下的 exclude 參數來設置。比如,我想關閉 DataSource,代碼具體如下:
1@SpringBootApplication(exclude = {DataSourceAutoConfiguration.class})
能滿足企業定制 logo 或項目啟動圖案。比如,可以借助如下幾個網站來生成:
1http://patorjk.com/software/taag
2http://www.network-science.de/ascii/
3http://www.kammerl.de/ascii/AsciiSignature.php
生成之后,直接將復制好的圖案,放到新建的 banner.txt 文件中。運行程序之后,具體顯示效果如下:
一般使用 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-properties
在 Spring Boot 應用中,可以內置 Tomcat、Netty、Jetty 等容器。
如果添加了 spring-boot-starter-web 依賴,則項目會默認使用 Tomcat 作為 Web 容器。
針對 Tomcat 可以添加一些配置,具體配置如下:
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# ...
在 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>
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@Component
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@Component
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@Component
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@Component
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 來源于:奈學開發者社區-江帥帥
“怎么使用Spring Boot”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。