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

简介: 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日志并进行多维度分析。
相关文章
|
3天前
|
Java 开发者 Spring
深入理解Spring Boot的@ComponentScan注解
【4月更文挑战第22天】在构建 Spring Boot 应用时,@ComponentScan 是一个不可或缺的工具,它使得组件发现变得自动化和高效。这篇博客将详细介绍 @ComponentScan 的基本概念、关键属性及其在实际开发中的应用。
20 4
|
4天前
|
Java 开发者 Spring
Spring Framework 中的 @Autowired 注解:概念与使用方法
【4月更文挑战第20天】在Spring Framework中,@Autowired 注解是实现依赖注入(Dependency Injection, DI)的一种非常强大的工具。通过使用 @Autowired,开发者可以减少代码中的引用绑定,提高模块间的解耦能力
28 6
|
2天前
|
Java
log4j异常日志过滤规则配置
log4j异常日志过滤规则配置
11 0
|
5天前
|
存储 安全 Java
第2章 Spring Security 的环境设置与基础配置(2024 最新版)(下)
第2章 Spring Security 的环境设置与基础配置(2024 最新版)(下)
13 0
|
5天前
|
安全 Java 数据库
第2章 Spring Security 的环境设置与基础配置(2024 最新版)(上)
第2章 Spring Security 的环境设置与基础配置(2024 最新版)
28 0
|
6天前
|
安全 Java Spring
Spring Security 5.7 最新配置细节(直接就能用),WebSecurityConfigurerAdapter 已废弃
Spring Security 5.7 最新配置细节(直接就能用),WebSecurityConfigurerAdapter 已废弃
18 0
|
6天前
|
安全 Java 应用服务中间件
江帅帅:Spring Boot 底层级探索系列 03 - 简单配置
江帅帅:Spring Boot 底层级探索系列 03 - 简单配置
24 0
江帅帅:Spring Boot 底层级探索系列 03 - 简单配置
|
8天前
|
XML Java C++
【Spring系列】Sping VS Sping Boot区别与联系
【4月更文挑战第2天】Spring系列第一课:Spring Boot 能力介绍及简单实践
【Spring系列】Sping VS Sping Boot区别与联系
|
12天前
|
JSON Java 数据库连接
属性注入掌握:Spring Boot配置属性的高级技巧与最佳实践
属性注入掌握:Spring Boot配置属性的高级技巧与最佳实践
21 1
|
12天前
|
XML Java 数据格式
进阶注解探秘:深入Spring高级注解的精髓与实际运用
进阶注解探秘:深入Spring高级注解的精髓与实际运用
26 2

热门文章

最新文章