上一篇博文我们讲解了如何创建一个springboot项目,接下来我们解释下启动类上的注解SpringBootApplication,该注解属于一个组合注解,我们看源码不难发现它会包含如下

@Target({ElementType.TYPE})
@Retention(RetentionPolicy.RUNTIME)
@Documented
@Inherited
@SpringBootConfiguration
@EnableAutoConfiguration
@ComponentScan(
    excludeFilters = {@Filter(
    type = FilterType.CUSTOM,
    classes = {TypeExcludeFilter.class}
), @Filter(
    type = FilterType.CUSTOM,
    classes = {AutoConfigurationExcludeFilter.class}
)}
)
public @interface SpringBootApplication {}

我们可以看到它组合了@SpringBootConfiguration、@EnableAutoConfiguration以及@ComponentScan,我们在开发的过程中如果不使用@SpringBootApplication,则可以组合使用这三个注解。唯一要注意的是如果我们使用了@SpringBootApplication注解的话,系统会去入口类的同级包以及下级包中去扫描实体类,因此我们建议入口类的位置在groupId+arctifactID组合的包名下

关闭特定的自动扫描配置

通过源码我们看到@ComponentScan注解是有一个过滤器的,如果不想扫描特定的类,我们可以将该类排除掉即可,代码配置如下

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)

定制banner

springboot在启动时都会打印出漂亮的springboot logo,其实这个图形是可以自定义修改的,修改该启动logo其实也很简单,只需要在src/main/resources下新建一个banner.txt文档 ,然后通过http://patorjk.com/software/taag网站生成需要的字符,将字符拷贝到步骤1所创建的txt文档中,比如我这里为Hello Sang!生成字符,如下:

springboot 启动类需要slf4 springboot启动类怎么写_加载

点击左下角拷贝粘贴到banner.txt文件即可!当然你也可以关闭banner图案,关闭也并不难,只需要在main方法内调用下关闭方法即可

public static void main(String[] args) {
        SpringApplicationBuilder builder = new SpringApplicationBuilder(Test19SpringBoot2Application.class);
        //修改Banner的模式为OFF
        builder.bannerMode(Banner.Mode.OFF).run(args);
    }

如此修改后我们在启动项目就不会看到难看的图形了,哈哈

springboot配置文件

Spring Boot使用一个全局的配置文件application.properties或者application.yml,配置文件放在src/main/resources目录下。properties是我们常见的一种配置文件,Spring Boot不仅支持properties这种类型的配置文件,也支持yaml语言的配置文件,我这里以properties类型的配置文件为例来看几个案例。

1.修改tomcat默认端口和访问路径 升级后的属性为server.servlet.context-path

server.context-path=/helloboot
server.port=8081

2.类型安全的读取配置文件内容

a.在src/main/resources文件夹下创建文件book.properties

book.name=红楼梦
book.author=曹雪芹
book.price=28

b.创建Book Bean,并注入properties文件中的值  可根据@propertySource加载指定配置文件

@PropertySource("classpath:properties/pay.properties")
@Component
@ConfigurationProperties(prefix = "book",locations = "classpath:book.properties")
public class BookBean {
    private String name;
    private String author;
    private String price;

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getAuthor() {
        return author;
    }

    public void setAuthor(String author) {
        this.author = author;
    }

    public String getPrice() {
        return price;
    }

    public void setPrice(String price) {
        this.price = price;
    }
}

prefix是指前缀,location指定要注入文件的位置。到此该BookBean已经加载到spring容器内了,使用方式和普通的service一样,直接引用即可

3.日志配置

默认情况下Spring Boot使用Logback作为日志框架,当然如果有需要我们可以手动配置日志级别以及日志输出位置,相比于我们在Spring容器中写的日志输出代码,这里的配置简直就是小儿科了,只需要在application.properties中添加如下代码:

logging.file=/home/sang/workspace/log.log
logging.level.org.springframework.web=debug