如何定制 Spring Boot 的 Banner?

相信用過 Spring Boot 的朋友們一定在啟動日志中見過類似如下的內(nèi)容,比如在啟動 Spring Boot 時,控制臺默認(rèn)會打印 Spring Boot Logo 以及版本信息,這是 Spring Boot 固定的還是可自定義的呢?

  .   ____          _            __ _ _
 /\\ / ___'_ __ _ _(_)_ __  __ _ \ \ \ \
( ( )\___ | '_ | '_| | '_ \/ _` | \ \ \ \
 \\/  ___)| |_)| | | | | || (_| |  ) ) ) )
  '  |____| .__|_| |_|_| |_\__, | / / / /
 =========|_|==============|___/=/_/_/_/
 :: Spring Boot ::        (v1.5.7.RELEASE)

答案是,Spring Boot 支持自定義 Banner,接下來本文將詳細(xì)討論如何定制 Banner 內(nèi)容,首先來了解下 Banner 是如何出現(xiàn)的。

Banner 是如何出現(xiàn)的?

初始 Banner 的代碼是 SpringApplicationBannerPrinter 類,Spring Boot 默認(rèn)尋找 Banner 的順序是:

  • 首先依次在 Classpath 下找文件 banner.gif,banner.jpg 和 banner.png,使用優(yōu)先找到的
  • 若沒找到上面文件的話,繼續(xù) Classpath 下找 banner.txt
  • 若上面都沒有找到的話, 用默認(rèn)的 SpringBootBanner,也就是上面輸出的 Spring Boot Logo

一般是把 banner.* 文件放在 src/main/resources/ 目錄下。

我們可以用屬性 banner.location 設(shè)定 Spring Boot 在不同于 Classpath 下找以上 banner.txt 文件,banner.charset 設(shè)定 banner.txt 的字符集,默認(rèn)為 UTF-8。屬性 banner.image.location 用于指定尋找 banner.(gif|jpg|png) 文件的位置。

如果同時存在圖片(如 banner.jpg) 和 banner.txt , 則它們會同時顯示出來,先圖片后文字,但同時存在多個圖片 banner.(gif|jpg|png),則只會顯示第一張圖片。

  • 對于文本文件,Spring Boot 會將其直接輸出。
  • 對于圖像文件( banner.gif 、banner.jpgbanner.png ),Spring Boot 會將圖像轉(zhuǎn)為 ASCII 字符,然后輸出。

變量

banner.txt 文件中還可以使用變量來設(shè)置字體、顏色、版本號。

變量 描述
${application.version} MANIFEST.MF 中定義的版本。如:1.0
${application.formatted-version} MANIFEST.MF 中定義的版本,并添加一個 v 前綴。如:v1.0
${spring-boot.version} Spring Boot 版本。如:1.5.7.RELEASE
${spring-boot.formatted-version} Spring Boot 版本,并添加一個 v 前綴。如:v1.5.7.RELEASE
${Ansi.NAME} (or ${AnsiColor.NAME}, ${AnsiBackground.NAME}, ${AnsiStyle.NAME}) ANSI 顏色、字體
${application.title} MANIFEST.MF 中定義的應(yīng)用名

配置

application.properties 中與 Banner 相關(guān)的配置:

# banner 模式。有三種模式:console/log/off
# console 打印到控制臺(通過 System.out)
# log - 打印到日志中
# off - 關(guān)閉打印
spring.main.banner-mode = off
# banner 文件編碼
spring.banner.charset = UTF-8
# banner 文本文件路徑
spring.banner.location = classpath:banner.txt
# banner 圖像文件路徑(可以選擇 png,jpg,gif 文件)
spring.banner.image.location = classpath:banner.gif
used).
# 圖像 banner 的寬度(字符數(shù))
spring.banner.image.width = 76
# 圖像 banner 的高度(字符數(shù))
spring.banner.image.height =
# 圖像 banner 的左邊界(字符數(shù))
spring.banner.image.margin = 2
# 是否將圖像轉(zhuǎn)為黑色控制臺主題
spring.banner.image.invert = false

當(dāng)然,也可以在 YAML 文件中配置,例如:

spring:
    banner:
        charset: UTF-8
        location: classpath:banner.txt

示例

新建 Spring Boot 項目(基于 Spring Boot 1.5.7)

package com.wupx.springboot;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;

@SpringBootApplication
public class BannerApplication {

    public static void main(String[] args) {
        SpringApplication.run(BannerApplication.class, args);
    }

}

在 Spring Boot 項目中的 resources 目錄下添加 banner.txt 文件,內(nèi)容如下:

${AnsiColor.BRIGHT_YELLOW}${AnsiStyle.BOLD}
__  _  ___________  ___
\ \/ \/ /\____ \  \/  /
 \     / |  |_> >    <
  \/\_/  |   __/__/\_ \
         |__|        \/
${AnsiColor.CYAN}${AnsiStyle.BOLD}
::  Java                 ::  (v${java.version})
::  Spring Boot          ::  (v${spring-boot.version})
${AnsiStyle.NORMAL}

啟動 Spring Boot 應(yīng)用后,控制臺輸出的 Banner 如下:

logo

推薦幾個生成字符畫的網(wǎng)站,可以將生成的字符畫放入這個 banner.txt 文件:

總結(jié)

默認(rèn) Spring Boot 會注冊一個 SpringBootBanner 的單例 Bean,用來負(fù)責(zé)打印 Banner。

如果想完全個人定制 Banner,可以先實現(xiàn) org.springframework.boot.Banner#printBanner 接口來自己定制 Banner。在將這個 Banner 通過 SpringApplication.setBanner() 方法注入 Spring Boot。

一般自定義 Spring Boot Banner 是企業(yè)/團(tuán)隊/項目的 Slogan。

參考

https://docs.spring.io/spring-boot/docs/current/reference/htmlsingle/#boot-features-banner

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容