spring boot學習(2): SpringApplication和自定義banner

SpringApplication

一般,我們用 SpringApplication 來啓動spring boot應用。如

@SpringBootApplication
public class DemoApplication {

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

}

還有其他兩種方式:

  1. 自定義SpringApplication:

    SpringApplication app = new SpringApplication(MySpringConfiguration.class);
    app.setBannerMode(Banner.Mode.OFF);
    app.run(args);
  2. 使用Builder:

    new SpringApplicationBuilder()
        .sources(Parent.class)
        .child(Application.class)
        .bannerMode(Banner.Mode.OFF)
        .run(args);

自定義banner

  1. 自定義文本

    resources 目錄下添加 banner.txt 文件:

     Test
     ${AnsiColor.YELLOW}
     Test Banner Text
    Application Version: ${application.version}${application.formatted-version}
    Spring Boot Version: ${spring-boot.version}${spring-boot.formatted-version}
    

    啓動應用時,顯示如下:

     Test
    
     Test Banner Text
    Application Version:
    Spring Boot Version: 2.1.3.RELEASE (v2.1.3.RELEASE)
  2. 自定義banner圖

    resources 目錄下添加 banner.png 文件
    啓動應用時顯示:

    
    
      @@@*@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@*@&@*@@@&@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @:*@@#@@@@@@@*#@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@#@@&@@*@@*@:@o@@@@:@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
      @@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
    
     Test
    
     Test Banner Text
    Application Version:
    Spring Boot Version: 2.1.3.RELEASE (v2.1.3.RELEASE)

    以上的 @ 行,其實是圖片 banner.png 的字符信息。

接下來看一下實現邏輯, 搜索 banner.txt:

class SpringApplicationBannerPrinter {
    static final String BANNER_LOCATION_PROPERTY = "spring.banner.location";

    static final String BANNER_IMAGE_LOCATION_PROPERTY = "spring.banner.image.location";

    static final String DEFAULT_BANNER_LOCATION = "banner.txt";

    static final String[] IMAGE_EXTENSION = { "gif", "jpg", "png" };

    private Banner getBanner(Environment environment) {
        Banners banners = new Banners();
        // 先添加圖片 banner
        banners.addIfNotNull(getImageBanner(environment)); 
        // 再添加文本信息的 banner
        banners.addIfNotNull(getTextBanner(environment));
        if (banners.hasAtLeastOneBanner()) {
            return banners;
        }
        // 沒有在運行環境中配置 banner 信息時, A
        if (this.fallbackBanner != null) {
            return this.fallbackBanner;
        }
        // 沒有任何的 banner 信息,使用默認
        return DEFAULT_BANNER;
    }

    private Banner getTextBanner(Environment environment) {
        String location = environment.getProperty(BANNER_LOCATION_PROPERTY,
                DEFAULT_BANNER_LOCATION);
        Resource resource = this.resourceLoader.getResource(location);
        if (resource.exists()) {
            return new ResourceBanner(resource);
        }
        return null;
    }

    private Banner getImageBanner(Environment environment) {
        String location = environment.getProperty(BANNER_IMAGE_LOCATION_PROPERTY);
        if (StringUtils.hasLength(location)) {
            Resource resource = this.resourceLoader.getResource(location);
            return resource.exists() ? new ImageBanner(resource) : null;
        }
        for (String ext : IMAGE_EXTENSION) {
            Resource resource = this.resourceLoader.getResource("banner." + ext);
            if (resource.exists()) {
                return new ImageBanner(resource);
            }
        }
        return null;
    }
}

代碼中可以看出:默認圖片的優先級由高到底爲:gif, jpg, png.

A 處的 fallbackBanner 是個啥:
搜索賦值的地方:

SpringApplicationBannerPrinter(ResourceLoader resourceLoader, Banner fallbackBanner) {
    this.resourceLoader = resourceLoader;
    this.fallbackBanner = fallbackBanner; 
}

SpringApplicationBannerPrinter 的使用的位置如下:

        // SpringApplication
    private Banner printBanner(ConfigurableEnvironment environment) {
        ......
        SpringApplicationBannerPrinter bannerPrinter = new SpringApplicationBannerPrinter(
                resourceLoader, this.banner);
        ......
    }

    public void setBanner(Banner banner) {
        this.banner = banner;
    }

因此我們可以對 SpringApplication 實例進行 banner 屬性的設置,使用方式:

  • SpringApplicationBuilder.banner()
  • SpringApplication.setBanner()

小結:

  1. 優先 spring.banner.locationspring.banner.image.location 配置的 banner
  2. 如果沒有配置,則使用 classpath 裏面的 banner.txt 或圖片內容, 圖片命名爲 banner.[ext], 其中 ext 的格式按照優先級高低依次是 gif, jpg, png,文本和圖片可以共存,先展示圖片,後展示文本。圖片內部展示時不能共存。
  3. 如果沒有在環境中配置,展示我們自己設置的自定義bannenr。
  4. 如果都沒有,則展示默認的banner。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章