1.Spring Boot如何加载外部配置文件?
Spring Boot 设计了一种非常灵活的方式来加载外部配置文件,允许你轻松地管理和调整应用程序的配置而无需改动代码。这些配置文件可以是 properties 文件、YAML 文件、环境变量或命令行参数。Spring Boot 在启动时会按照特定的顺序来加载这些配置,这个顺序确保了特定配置的优先级,使得某些配置可以覆盖其他配置。
配置文件的加载顺序
以下是 Spring Boot 加载外部配置文件的一般顺序,较高的配置覆盖较低的配置:
- 命令行参数
- 来自 SPRING_APPLICATION_JSON 的属性(环境变量或系统属性中的内联 JSON)
- ServletConfig 初始化参数
- ServletContext 初始化参数
- JNDI 属性
- Java 系统属性(
System.getProperties()
) - 操作系统环境变量
- 随机生成的配置属性(用于注入随机值如端口号等)
- 应用程序在打包时打包到应用内部的配置文件(application.properties 或 application.yml,包括通过 profile 定义的变种)
- 在应用程序外部的配置文件(运行时指定的位置,例如通过
--spring.config.location
指定的文件或路径) - 通过配置服务加载的配置属性(例如 Spring Cloud Config)
@Configuration
类上的@PropertySource
注解- 默认属性(通过
SpringApplication.setDefaultProperties
指定)
如何指定外部配置文件
- 命令行参数:可以在启动应用时通过命令行参数指定配置属性,如
java -jar app.jar --server.port=8081
。 - 应用属性文件:默认情况下,Spring Boot 从应用的 classpath 下的
application.properties
或application.yml
文件加载配置。 - 环境变量:可以设置环境变量来覆盖配置,特别是在云环境或容器环境中非常有用。
- 外部配置文件位置:使用
--spring.config.location
命令行参数指定外部配置文件的位置,可以是文件路径或目录路径。
使用 Profile
Spring Boot 允许你为不同的环境定义不同的配置文件,称为“profiles”。这些文件命名为 application-{profile}.properties
或 application-{profile}.yml
。你可以通过设置 spring.profiles.active
环境变量来激活特定的配置文件。
通过这些机制,Spring Boot 提供了一种强大而灵活的方式来管理应用配置,使得应用能够适应不同的环境和需求,而无需改动代码。
2. Spring Boot如何实现跨域请求?
在Spring Boot中实现跨域请求(CORS,Cross-Origin Resource Sharing),有几种常用的方法:
1. @CrossOrigin
注解
最简单的方式是在控制器(Controller)或者具体的方法上使用@CrossOrigin
注解。这个注解允许你细致地控制哪些请求来源、HTTP方法等被允许访问。
示例:
import org.springframework.web.bind.annotation.CrossOrigin;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;
@RestController
@CrossOrigin(origins = "http://example.com") // 允许来自http://example.com的跨域请求
public class MyController {
@GetMapping("/greeting")
public String greeting() {
return "Hello, World";
}
}
2. 全局配置
如果你想为所有的控制器配置CORS策略,可以使用WebMvcConfigurer
接口。
示例:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.web.servlet.config.annotation.CorsRegistry;
import org.springframework.web.servlet.config.annotation.WebMvcConfigurer;
@Configuration
public class MyConfiguration {
@Bean
public WebMvcConfigurer corsConfigurer() {
return new WebMvcConfigurer() {
@Override
public void addCorsMappings(CorsRegistry registry) {
registry.addMapping("/**") // 对所有路径应用规则
.allowedOrigins("http://example.com") // 允许来自http://example.com的请求
.allowedMethods("GET", "POST", "PUT", "DELETE"); // 允许指定的请求方法
}
};
}
}
3. Spring Security 配置
如果你的项目中集成了Spring Security,你需要在Spring Security的配置中添加CORS配置,因为Spring Security的安全控制会优先于CORS配置生效。
示例:
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import org.springframework.security.config.annotation.web.builders.HttpSecurity;
import org.springframework.security.config.annotation.web.configuration.EnableWebSecurity;
import org.springframework.security.config.annotation.web.configuration.WebSecurityConfigurerAdapter;
import org.springframework.security.web.authentication.UsernamePasswordAuthenticationFilter;
import org.springframework.web.cors.CorsConfiguration;
import org.springframework.web.cors.UrlBasedCorsConfigurationSource;
import org.springframework.web.filter.CorsFilter;
@Configuration
@EnableWebSecurity
public class SecurityConfig extends WebSecurityConfigurerAdapter {
@Override
protected void configure(HttpSecurity http) throws Exception {
http
// 其他配置...
.cors().and() // 启用CORS配置
// 其他配置...
}
@Bean
public CorsFilter corsFilter() {
UrlBasedCorsConfigurationSource source = new UrlBasedCorsConfigurationSource();
CorsConfiguration config = new CorsConfiguration();
config.setAllowCredentials(true); // 允许cookies跨域
config.addAllowedOrigin("http://example.com");
config.addAllowedHeader("*");
config.addAllowedMethod("*");
source.registerCorsConfiguration("/**", config);
return new CorsFilter(source);
}
}
选择适合你需求的方法来实现跨域请求的支持。通常,对于小规模或特定的需求,使用@CrossOrigin
注解是最简单直接的方式。而对于需要全局配置跨域策略的情况,通过全局配置或者Spring Security配置会更加合适。
3. Spring Boot的热部署是如何实现的?
Spring Boot 的热部署(也称为热重载)允许开发者在应用运行时更新部分资源(如代码、配置和静态资源),而无需重新启动整个应用。这大大加快了开发过程,因为你可以立即看到更改的效果。Spring Boot 可以通过使用 Spring Loaded 或 Spring Boot DevTools 来实现热部署。
使用 Spring Boot DevTools 实现热部署
Spring Boot DevTools 是 Spring Boot 官方提供的一个模块,旨在提高开发效率。它提供了一系列开发时的便利功能,包括自动重启、模板引擎的缓存禁用等。自动重启是实现热部署的关键特性。
如何配置:
- 添加 DevTools 依赖:首先,你需要在你的项目中加入 Spring Boot DevTools 的依赖。如果你使用 Maven,可以在
pom.xml
中添加如下依赖:
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<scope>runtime</scope>
<optional>true</optional>
</dependency>
</dependencies>
如果你使用 Gradle,则添加如下依赖:
dependencies {
developmentOnly("org.springframework.boot:spring-boot-devtools")
}
启用自动重启:仅通过添加 DevTools 依赖,大部分情况下自动重启功能就已经启用。Spring Boot DevTools 默认会监控项目路径下的文件变动,并在检测到更改时重新启动应用。
配置 IDEA 或其他 IDE:在某些 IDE 中,比如 IntelliJ IDEA,你需要确保「Build Project Automatically」设置被启用(可以在 Preferences -> Compiler 中找到)。对于 Eclipse,你可能需要安装额外的插件来支持自动编译。
工作原理:
- 当你保存对项目中的文件的更改时,IDE 会自动编译更改过的文件。
- Spring Boot DevTools 检测到类路径上的更改后,会触发应用的重启。
- 为了缩短重启时间,DevTools 使用两个类加载器:一个用于第三方库(不变的部分),另一个用于项目的类(会变动的部分)。只有会变动的部分在重启时被重新加载,从而加快了重启速度。
注意事项
虽然热部署提高了开发效率,但它也有一些限制。例如,更改不能改变已有的 bean 定义或是添加新的 bean。对于这种类型的更改,仍然需要重新启动应用。此外,使用 DevTools 时,由于它的工作原理,可能会与某些库产生兼容性问题。因此,虽然它非常适合开发环境,但不建议在生产环境中使用 DevTools。