Spring Boot核心之基本配置、日志配置、自动配置、条件注解

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: Spring Boot核心之基本配置、日志配置、自动配置、条件注解

Spring Boot的基本配置


启动类和核心注解


Spring Boot应用通常都有一个名为*Application的程序入口类 该入口类需要使用Spring Boot的核心注解@SpringBootApplicaiton标注为应用的启动类 该入口类有一个标准的Java应用程序的main方法 代码如下

package com.ch.ch4_1;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
@SpringBootApplication
public class Ch41Application {
  public static void main(String[] args) {
  SpringApplication.run(Ch41Application.class, args);
  }
}


Spring Boot的全局配置文件


1:设置端口号


例如在项目的src/main/resources目录下找到名为application.properties的全局配置文件 添加如下配置文件


server.port=8888


可以将内嵌的Tomcat的默认端口改为8888


2:设置Web应用的上下文路径


同样在application.properties文件下配置如下内容


server.servlet.context-path=/xxx


Spring Boot的Starters


Spring Boot提供了很多简化企业级开发的开箱即用的Starters 可以自动关联项目开发所需要的相关依赖 如在pom.xml中添加如下配置 则Spring Boot将会自动关联Web开发的相关依赖

<dependency>
   <groupId>org.springframework.boot</groupId>
   <artifactId>spring-boot-starter-web</artifactId>
</dependency>


读取应用配置


Spring Boot提供了三种方式读取项目的application.properties配置文件的内容 分别是Environment类 @Value注解以及@ConfigurationProperties注解


1:Environment


Environment是一个通用的读取应用程序运行时环境变量的类 可以通过key-value方式读取


快速创建一个Spring Boot Web应用 如果不会可以参考我这篇文章


快速构建Spring Boot


在application.properties文件中加入


test.msg=read config


创建一个名为EnvReaderConfigController的类 代码如下

package com.test.ch3_2.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class EnvReaderConfigController {
@Autowired
private Environment env;
@RequestMapping("/testEnv")
public String testEnv() {
  return "方法一"+env.getProperty("test.msg");
}
}


在运行main方法 发现配置已经读进去了


2:@Value


使用@Value注解读取配置文件内容示例代码如下

@Value ("${test.msg})
private String msg;


3:@ConfigurationProperties


使用它则首先建立配置文件与对象的映射关系 然后在控制器方法中使用@Autowired注解将对象注入 首先在application.properties加入以下代码


obj.sname=chenheng

obj.sage=88


创建StudentProperties类

package com.ch.ch4_1.model;
import org.springframework.boot.context.properties.ConfigurationProperties;
import org.springframework.stereotype.Component;
@Component//使用Component注解,声明一个组件,被控制器依赖注入
@ConfigurationProperties(prefix = "obj")//obj为配置文件中key的前缀
public class StudentProperties {
  private String sname;
  private int sage;
  public String getSname() {
  return sname;
  }
  public void setSname(String sname) {
  this.sname = sname;
  }
  public int getSage() {
  return sage;
  }
  public void setSage(int sage) {
  this.sage = sage;
  }
  @Override
    public String toString() {
        return "StudentProperties [sname=" + sname + ", sage=" + sage + "]";
    }
}


创建ConfigurationPropertiesController类

package com.ch.ch4_1.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
import com.ch.ch4_1.model.StudentProperties;
@RestController
public class ConfigurationPropertiesController {
  @Autowired
  StudentProperties studentProperties;
  @RequestMapping("/testConfigurationProperties")
  public String  testConfigurationProperties() {
   return studentProperties.toString();
  }
}


日志配置


默认情况下 Spring Boot项目使用LogBack实现入职 使用apache Commons Logging作为日志接口 因此代码中通常如下使用日志

package com.ch.ch4_1.controller;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.core.env.Environment;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
public class LogTestController{
   private Log log=LogFactory.getLog(LogTestController.class);
  @RequestMapping("/testLog")
 public String testLog(){
 log.info("测试日志);
return "测试日志";
}
}


Spring Boot的自动配置原理


Spring Boot是通过加载所有META-INF/spring.factories配置文件进行自动配置的 所以@SpringBootApplication注解通过使用@EnableAutoConfiguration注解自动配置的原理是:从classpath中搜索所有META-INF/spring.factories配置文件并将其中,并将其中org.springframework.boot.autoconfigure.EnableAutoConfigturation对应的配置项通过Java反射机制进行实例化,然后汇总并加载到Spring的IOC容器


Spring Boot的条件注解


所谓Spring的条件注解 就是应用程序的配置类的配置项 在满足某些特定条件后才会被自动启用


下图所有的条件注解都是组合了@Conditional元注解 只是针对不同的条件去实现


1666445119540.jpg

1666445129400.jpg





 


相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
相关文章
|
9天前
|
XML 安全 Java
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
本文介绍了Java日志框架的基本概念和使用方法,重点讨论了SLF4J、Log4j、Logback和Log4j2之间的关系及其性能对比。SLF4J作为一个日志抽象层,允许开发者使用统一的日志接口,而Log4j、Logback和Log4j2则是具体的日志实现框架。Log4j2在性能上优于Logback,推荐在新项目中使用。文章还详细说明了如何在Spring Boot项目中配置Log4j2和Logback,以及如何使用Lombok简化日志记录。最后,提供了一些日志配置的最佳实践,包括滚动日志、统一日志格式和提高日志性能的方法。
107 30
【日志框架整合】Slf4j、Log4j、Log4j2、Logback配置模板
|
6天前
|
Java 中间件
SpringBoot入门(6)- 添加Logback日志
SpringBoot入门(6)- 添加Logback日志
40 5
|
29天前
|
Java API 数据库
构建RESTful API已经成为现代Web开发的标准做法之一。Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐。
【10月更文挑战第11天】本文介绍如何使用Spring Boot构建在线图书管理系统的RESTful API。通过创建Spring Boot项目,定义`Book`实体类、`BookRepository`接口和`BookService`服务类,最后实现`BookController`控制器来处理HTTP请求,展示了从基础环境搭建到API测试的完整过程。
39 4
|
26天前
|
Java API 数据库
Spring Boot框架因其简洁的配置、快速的启动特性及丰富的功能集而备受开发者青睐
本文通过在线图书管理系统案例,详细介绍如何使用Spring Boot构建RESTful API。从项目基础环境搭建、实体类与数据访问层定义,到业务逻辑实现和控制器编写,逐步展示了Spring Boot的简洁配置和强大功能。最后,通过Postman测试API,并介绍了如何添加安全性和异常处理,确保API的稳定性和安全性。
34 0
|
19天前
|
Java API Spring
在 Spring 配置文件中配置 Filter 的步骤
【10月更文挑战第21天】在 Spring 配置文件中配置 Filter 是实现请求过滤的重要手段。通过合理的配置,可以灵活地对请求进行处理,满足各种应用需求。还可以根据具体的项目要求和实际情况,进一步深入研究和优化 Filter 的配置,以提高应用的性能和安全性。
|
6天前
|
缓存 IDE Java
SpringBoot入门(7)- 配置热部署devtools工具
SpringBoot入门(7)- 配置热部署devtools工具
18 2
 SpringBoot入门(7)- 配置热部署devtools工具
|
5天前
|
Java 数据库连接
SpringBoot配置多数据源实战
第四届光学与机器视觉国际学术会议(ICOMV 2025) 2025 4th International Conference on Optics and Machine Vision
29 8
|
2天前
|
Java 数据库连接 数据库
springboot启动配置文件-bootstrap.yml常用基本配置
以上是一些常用的基本配置项,在实际应用中可能会根据需求有所变化。通过合理配置 `bootstrap.yml`文件,可以确保应用程序在启动阶段加载正确的配置,并顺利启动运行。
8 2
|
11天前
|
Java Spring
[Spring]aop的配置与使用
本文介绍了AOP(面向切面编程)的基本概念和核心思想。AOP是Spring框架的核心功能之一,通过动态代理在不修改原代码的情况下注入新功能。文章详细解释了连接点、切入点、通知、切面等关键概念,并列举了前置通知、后置通知、最终通知、异常通知和环绕通知五种通知类型。
24 1
|
14天前
|
Java Spring 容器
SpringBoot读取配置文件的6种方式,包括:通过Environment、@PropertySource、@ConfigurationProperties、@Value读取配置信息
SpringBoot读取配置文件的6种方式,包括:通过Environment、@PropertySource、@ConfigurationProperties、@Value读取配置信息
40 3