From 1bbca46b72c8d0fdd63b0286a6234b187bea5433 Mon Sep 17 00:00:00 2001 From: odboy Date: Fri, 6 Dec 2024 21:11:01 +0800 Subject: [PATCH] =?UTF-8?q?upd:=20=E5=8A=A8=E6=80=81=E5=8F=98=E6=9B=B4?= =?UTF-8?q?=E7=8E=AF=E5=A2=83=E5=8F=98=E9=87=8F=E6=B5=8B=E8=AF=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../java/cn/odboy/rest/DemoController.java | 42 +++++++++++++++---- 1 file changed, 33 insertions(+), 9 deletions(-) diff --git a/kenaito-config-demo/src/main/java/cn/odboy/rest/DemoController.java b/kenaito-config-demo/src/main/java/cn/odboy/rest/DemoController.java index ed3b027..bbdb7e8 100644 --- a/kenaito-config-demo/src/main/java/cn/odboy/rest/DemoController.java +++ b/kenaito-config-demo/src/main/java/cn/odboy/rest/DemoController.java @@ -1,19 +1,43 @@ package cn.odboy.rest; -import lombok.RequiredArgsConstructor; +import java.util.HashMap; +import java.util.Map; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.beans.factory.annotation.Value; +import org.springframework.core.env.ConfigurableEnvironment; +import org.springframework.core.env.MapPropertySource; import org.springframework.http.ResponseEntity; -import org.springframework.web.bind.annotation.PostMapping; +import org.springframework.web.bind.annotation.GetMapping; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; - +/** + * 全局更新配置测试 + * + * @author odboy + * @date 2024-12-06 + */ @RestController -@RequiredArgsConstructor -@RequestMapping("/api/demo") +@RequestMapping("/updateConfig") public class DemoController { + @Value("${kenaito.config-center.demo:123}") + private String demoStr; - @PostMapping("/test") - public ResponseEntity test() { - return ResponseEntity.ok("success"); - } + @Autowired private ConfigurableEnvironment environment; + + /** 配置变化了 */ + @GetMapping("/test") + public ResponseEntity test() { + String key = "kenaito.config-center.demo"; + String property = environment.getProperty(key); + System.err.println("property=" + property); + Map properties = new HashMap<>(); + properties.put(key, "Hello World!"); + MapPropertySource propertySource = new MapPropertySource("dynamicProperties", properties); + // 将新的属性源添加到 ConfigurableEnvironment 中 + environment.getPropertySources().addFirst(propertySource); + String property1 = environment.getProperty(key); + System.err.println("property1=" + property1); + return ResponseEntity.ok("success"); + } }