慕少森
Spring Boot 默认寻找 Banner 的顺序是:依次在 Classpath 下找 文件 banner.gif , banner.jpg , 和 banner.png , 先找到谁就用谁继续 Classpath 下找 banner.txt上面都没有找到的话, 用默认的 SpringBootBanner , 就是我们最常见到的那个既然是 Classpath 的资源, 我们按照 Maven 项目的惯例, 是把 banner.* 文件放在 src/main/resources/ 目录下.我们可以用属性 banner.location 设定 Spring Boot 在不同于 Classpath 下找以上 banner.txt 文件. banner.charset 设定 banner.txt 的字符集, 默认为 UTF-8 . 属性. banner.image.location 用于指定寻找 banner.(gif|jpg|png) 文件的位置.如果同时存在图片(如 banner.jpg) 和 banner.txt , 则它们会同时显示出来, 先图片后文字. 但同时存在多个图片 banner.(gif|jpg|png) , 则只会显示第一张图片.下面依次介绍 图片 Banner, 文字 Banner, 和代码定制法, 其中 文字 Banner 只须在 src/main/resources 加上 banner.txt 应该是最简单实用的, 其次就是用简洁的 banner 图片 .图片 Banner我们或许有疑问了, 对于图片文件 banner.(gif|jpg|png) 文件, Spring Boot 该如何在控制台显示. 由于我们的控制台只管显示字符, 所以 Spring Boot 会尽力把这三种图片文件转换成字符表示, 还带有 AnsiColor 颜色的.想要知道 Spring Boot 的 ImageBanner 对图片的理解程序到底有多强, 可以试下把这张图片放到 src/main/resources/ 下,然后重新启动一下我们的 Spring Boot 程序, 可以看到如下效果把图片转换成带色的字符显示已经很不错的了, 当然你不能太难为 Spring Boot 了, 图片色彩稍复杂肯定是一团糟. 图片到文字的转换的实际效果可以尝试 Spring Boot 官方的 Banner Generator .文字 Banner如果使用 banner.txt 定义 Banner 的话, 里面可以使用如下变量${application.version} , ${application.formatted-version} , ${spring-boot.version} , ${Ansi.NAME} 或 ${AnsiColor .NAME} , ${AnsiBackground.NAME} , ${AnsiStyle.NAME} , ${application.title} , 这些具体定义请参考 Spring Boot 的官方文档 Customizing the Banner .这里说一下 AnsiColor , AnsiStyle , 和 AnsiBackground 的用法, 它们是各种 Ansi 控制符 , 见 Wiki ANSI escape code . 可取值请参考各自相应的类, org.springframework.boot.ansi.(AnsiColor|AnsiStyle|AnsiStyle) . 分别用于定义字符在控制台下显示的颜色, 风格与背景色.这里有一个 banner.txt , 内容是${AnsiColor.RED}${AnsiStyle.ITALIC}I'm Red and italic ${AnsiStyle.NORMAL}${AnsiColor.DEFAULT}${AnsiColor.BLUE}${AnsiBackground.YELLOW}I'm Blue with yellow background${AnsiBackground.DEFAULT}${AnsiColor.DEFAULT}${AnsiColor.GREEN}Powered by ${spring-boot.formatted-version}${AnsiColor.DEFAULT}执行 Spring Boot 应用后输出对应的 Banner 如下图另外, 如果我们不满足于定义在 banner.txt 中的文字原本平实的显示出来, 也可以像默认的Spring Boot 的 Banner 那样, 把字符串转换为特殊字符组成的艺术字体, 这还有一个专用名词 TAAG(Text toASCII Art Generator). 有许多在线网站能帮你转换, 只要 Google 搜索 text to ascii art generator . 举几个例子:http://patorjk.com/software/taag/#p=display&f=Jacky&t=unmi.cchttp://www.desmoulins.fr/index_us.php?pg=scripts!online!asciiarthttp://asciiset.com/figletserver.htmlhttp://www.askapache.com/online-tools/figlet-ascii/h ttp://picascii.com/ 图片转换为 ASCII把喜欢的文字转换一下, 贴到 banner.txt 中即可, 高兴的话再用 ${AnsiColor.NAME} 等再加润色.其他 Banner 定制或者可以完全定制 Banner, 通过代码SpringApplication bootstrap = new SpringApplication(SampleController.class);bootstrap.setBanner(new Banner() {@Overridepublic void printBanner(Environment environment, Class<?> aClass, PrintStream printStream) {//往 printStream 中输出吧, 可从 environment 中取属性配置}});// bootstrap.setBannerMode(Banner.Mode.LOG);bootstrap.run(args);Banner.Mode 有三个值 CONSOLE, LOG, OFF, 默认为 CONSOLE, 可以用 OFF 关闭 Banner 显示, 或是 LOG 让 Banner 在应用 log 中显示. 可支持用属性 spring.main.banner-mode=off 来控制.因为前面两种图片和文字 Banner 已经非常强大了, 所以本人觉得完全用 setBanner(banner) 来定制没多大必要, 至多在不想要任何 Banner 的时候可以用 spring.main.banner-mode=off 进行关闭.或使用 Fluent builder APInew SpringApplicationBuilder(Xxx.class).bannerMode(Banner.Mode.OFF).run(args);