springboot + nacos + aws secretmanager 做賬號密碼隱私處理

方式一:

#nacos配置文件data.yml:
spring:cloud:nacos:discovery:ip: ****.comport: 80datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://*********/database?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&failOverReadOnly=false&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=convertToNullhikari:idle-timeout: 60000connection-timeout: 60000validation-timeout: 3000login-timeout: 5max-lifetime: 60000maximum-pool-size: 20#項目配置文件bootstrap-test.yml
spring:cloud:nacos:discovery:server-addr: http://nacos-headless:8848config:server-addr: http://nacos-headless:8848namespace: TESTfile-extension: ymlextension-configs:- group: DEFAULT_GROUPdata-id: global.yml- group: commondata-id: common.yml- group: datadata-id: db.ymlrefresh: truesm:?region: eu-central-1doc: dev-fra-as-api-mongodb-user-root-ZMEAVyQppET6GPfrdsp: dev-fra-as-api-rds-user-root-xp78N8GvtScLmGnrdss: dev-fra-as-pms-rds-v2-readonly-from-sin-user-fra-appplayer-gp3Sex9vbXDU6PL代碼package com.yuruo.reco.config;import java.util.HashMap;
import java.util.Map;import org.springframework.boot.SpringApplication;
import org.springframework.boot.env.EnvironmentPostProcessor;
import org.springframework.core.env.ConfigurableEnvironment;
import org.springframework.core.env.MapPropertySource;
import org.springframework.core.env.MutablePropertySources;
import org.springframework.core.env.PropertySource;import com.yuruo.reco.dto.SecretDto;
import com.yuruo.reco.utils.JsonUtils;import software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.secretsmanager.SecretsManagerClient;
import software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest;public class SecretsManagerEnvironmentPostProcessor implements EnvironmentPostProcessor {@Overridepublic void postProcessEnvironment(ConfigurableEnvironment environment, SpringApplication application) {MutablePropertySources propertySources = environment.getPropertySources();for (PropertySource<?> propertySource : propertySources) {if (propertySource.getName().contains("[bootstrap-" + environment.getActiveProfiles()[0] + ".yml]")) {Region region = Region.of(propertySource.getProperty("sm.region").toString());SecretsManagerClient client = SecretsManagerClient.builder().region(region).credentialsProvider(DefaultCredentialsProvider.create()).build();// 讀取配置String primarySecret = getSecretRes(client, propertySource.getProperty("sm.rdsp").toString());SecretDto secret = JsonUtils.stringToJavaObject(primarySecret, SecretDto.class);Map<String, Object> source = new HashMap<>();source.put("spring.datasource.primary.username", secret.getUsername());source.put("spring.datasource.primary.password", secret.getPassword());String secondarySecret = getSecretRes(client, propertySource.getProperty("sm.rdss").toString());secret = JsonUtils.stringToJavaObject(secondarySecret, SecretDto.class);source.put("spring.datasource.secondary.username", secret.getUsername());source.put("spring.datasource.secondary.password", secret.getPassword());String mongosecret = getSecretRes(client, propertySource.getProperty("sm.doc").toString());secret = JsonUtils.stringToJavaObject(mongosecret, SecretDto.class);source.put("spring.data.mongodb.uri", "mongodb://" + secret.getUsername() + ":" + secret.getPassword()+ "@" + secret.getHost() + ":" + secret.getPort());propertySources.addLast(new MapPropertySource("secretsManagerPropertySource", source));}}}private String getSecretRes(SecretsManagerClient client, String secretName) {GetSecretValueRequest request = GetSecretValueRequest.builder().secretId(secretName).build();return client.getSecretValue(request).secretString();}}

方式二:

src/main/resources/META-INF/spring.factories
org.springframework.boot.env.EnvironmentPostProcessor=com.yuruo.reco.config.SecretsManagerEnvironmentPostProcessorspring:jpa:properties:hibernate:dialect: org.hibernate.dialect.MySQL8Dialectcloud:nacos:discovery:ip: ****.comport: 80datasource:driver-class-name: com.mysql.cj.jdbc.Driverurl: jdbc:mysql://*********/database?useUnicode=true&characterEncoding=UTF-8&autoReconnect=true&failOverReadOnly=false&serverTimezone=Asia/Shanghai&zeroDateTimeBehavior=convertToNullusername: ${DB_USETRNAME}password: ${DB_PASSWORD}hikari:idle-timeout: 60000connection-timeout: 60000validation-timeout: 3000login-timeout: 5max-lifetime: 60000maximum-pool-size: 20package com.yuruo.reco.config;import org.apache.commons.lang3.StringUtils;
import org.springframework.boot.SpringApplication;
import org.springframework.boot.env.EnvironmentPostProcessor;
import org.springframework.core.env.ConfigurableEnvironment;import com.yuruo.reco.constant.SecretConstant;
import com.yuruo.reco.dto.SecretDto;
import com.yuruo.reco.utils.JsonUtils;import software.amazon.awssdk.auth.credentials.DefaultCredentialsProvider;
import software.amazon.awssdk.regions.Region;
import software.amazon.awssdk.services.secretsmanager.SecretsManagerClient;
import software.amazon.awssdk.services.secretsmanager.model.GetSecretValueRequest;public class SecretsManagerEnvironmentPostProcessor implements EnvironmentPostProcessor {@Overridepublic void postProcessEnvironment(ConfigurableEnvironment environment, SpringApplication application) {Region region = Region.of(SecretConstant.SECRET_REGION);SecretsManagerClient client = SecretsManagerClient.builder().region(region).credentialsProvider(DefaultCredentialsProvider.create()).build();String primarySecret = getSecretRes(client, SecretConstant.SECRET_PRIMARY);if(StringUtils.isNotBlank(primarySecret)) {SecretDto secret = JsonUtils.stringToJavaObject(primarySecret, SecretDto.class);System.setProperty("DB1_USETRNAME", secret.getUsername());System.setProperty("DB1_PASSWORD", secret.getPassword());}String secondarySecret = getSecretRes(client, SecretConstant.SECRET_SECONDARY);if(StringUtils.isNotBlank(secondarySecret)) {SecretDto secret = JsonUtils.stringToJavaObject(secondarySecret, SecretDto.class);System.setProperty("DB2_USETRNAME", secret.getUsername());System.setProperty("DB2_PASSWORD", secret.getPassword());}String mongosecret = getSecretRes(client, SecretConstant.SECRET_MONGO);if(StringUtils.isNotBlank(mongosecret)) {SecretDto secret = JsonUtils.stringToJavaObject(mongosecret, SecretDto.class);System.setProperty("MGDB_URI", "mongodb://"+secret.getUsername()+":"+secret.getPassword()+"@"+ secret.getHost()+":"+secret.getPort()+"/?replicaSet=rs0&readPreference=secondaryPreferred&retryWrites=false");}}private String getSecretRes(SecretsManagerClient client, String secretName) {GetSecretValueRequest request = GetSecretValueRequest.builder().secretId(secretName).build();return client.getSecretValue(request).secretString();}}

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/712310.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/712310.shtml
英文地址,請注明出處:http://en.pswp.cn/news/712310.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java 商機管理系統Myeclipse開發mysql數據庫web結構jsp編程計算機網頁項目

一、源碼特點 java 商機管理系統是一套完善的java web信息管理系統&#xff0c;對理解JSP java編程開發語言有幫助&#xff0c;系統具有完整的源代碼和數據庫&#xff0c;系統主要采用B/S模式開發。開發環境為 TOMCAT7.0,Myeclipse8.5開發&#xff0c;數據庫為Mysql5.0&…

LeetCode142. 環形鏈表 II刷題詳解

今天力扣刷到了一個特別有意思的題目&#xff0c;于是就寫了下面的題解來加深以下理解。 142. 環形鏈表 II - 力扣&#xff08;LeetCode&#xff09; 這個可以分為兩大步去寫&#xff0c;首先要判斷鏈表是否有環&#xff0c;然后如果有環就去找到環的入口&#xff0c;沒有環返…

python3.x的在線與離線安裝純凈版

由于計劃搭建一套使用python自動分析日志的流程&#xff0c;發現我們的測試環境CentOS 7仍然沒有安裝python3&#xff0c;無法使用這些新的庫。Python 3在設計上著重提升了語言的一致性和易用性&#xff0c;它引入了許多關鍵改進&#xff0c;此外&#xff0c;Python 3環境擁有豐…

基于springboot+html實現的衣物捐贈平臺

一、系統架構 前端&#xff1a;html | layui | jquery | css 后端&#xff1a;springboot | thymeleaf | mybatis 環境&#xff1a;jdk1.8 | mysql | maven 二、代碼及數據庫 三、功能介紹 01. 登錄頁 02. 注冊 03. web頁-首頁 04. web頁-捐贈衣服 05. web頁-論壇交流…

C# 中的 IReadOnlyDictionary 和 IReadOnlyList

C# 中的 IReadOnlyDictionary 和 IReadOnlyList 是接口&#xff0c;用于表示只讀的字典和只讀的列表。這些接口提供了對集合的只讀訪問權限&#xff0c;即不允許對集合進行修改操作&#xff0c;例如添加、刪除或修改元素。這種只讀特性對于需要保護數據完整性或只需要進行讀取操…

MYSQL--鎖機制*

一.對鎖機制的大概介紹: 1.大概的來說,MYSQL當中的鎖實際上就是合理的管理多個服務器對于同一個共享資源的使用,是計算機協調多個進程或者是線程并發訪問某一資源的機制(避免爭搶資源的現象發生) 2.在數據庫當中,數據是一種可以供許多的用戶進行共享使用的資源,如何保證數據并發…

軟考筆記--軟件開發模型

軟件開發模型給出了軟件開發活動各個階段之間的關系&#xff0c;它是軟件開發過程的概括&#xff0c;是軟件工程的重要內容。軟件開發模型為軟件工程管理提供了里程碑和進度表&#xff0c;為軟件開發過程提供了原則和方法。 一.軟件開發模型概述 軟件開發模型可分為三種類型&…

第十一屆藍橋杯省賽第一場C++ A組 / B組《整數拼接》(c++)

1.題目說明 給定一個長度為 n 的數組 A1,A2,???,An。 你可以從中選出兩個數 Ai 和 Aj(i 不等于 j)&#xff0c;然后將 Ai 和 Aj 一前一后拼成一個新的整數。 例如 12 和 345 可以拼成 12345 或 34512。 注意交換 Ai 和 Aj 的順序總是被視為 2 種拼法&#xff0c;即便是 …

考研倒計時半年:如何高效安排學習計劃?

距離考研還有半年的時間&#xff0c;這是一個既緊張又充滿希望的階段。如何利用好這段時間&#xff0c;制定一個高效的學習計劃&#xff0c;成為了每位考生關注的焦點。下面&#xff0c;我將為大家提供一些關于政治、英語和專業課的學習建議&#xff0c;希望能對大家有所幫助。…

曲線的凹凸性與拐點【高數筆記】

1.什么是曲線的凹凸性 2.什么是曲線的拐點 3.拐點的特征 4.拐點與駐點有什么不同 5.拐點的表示方法與駐點有什么不一樣 6.拐點與凹凸區間怎么求

力扣121題: 買賣股票的最佳時機

【題目描述】 給定一個數組 prices &#xff0c;它的第 i 個元素 prices[i] 表示一支給定股票第 i 天的價格。你只能選擇 某一天 買入這只股票&#xff0c;并選擇在 未來的某一個不同的日子賣出該股票。設計一個算法來計算你所能獲取的最大利潤。返回你可以從這筆交易中獲取的最…

Mathtype安裝時word啟動顯示“文件未找到:MathPage.WLL”

背景 由于老板布置的臨時工作&#xff0c;需要安裝Mathtype&#xff0c;但嘗試了3個不同的版本后&#xff08;每次都卸載干凈了&#xff09;&#xff0c;均未能成功安裝&#xff0c;出現的報錯3個版本各不相同&#xff1a; ①解壓安裝過程中失敗&#xff08;這個版本不再嘗試…

GoFrame:如何簡單地搭建一個簡單地微服務

一切資料來源于GoFrame官網, 感興趣的, 可以直接去官網查閱相關資料。 首先下載框架工具, 下載地址:https://github.com/gogf/gf/releases 然后進入你想要放置的項目文件夾, 執行命令行 gf init {project_name} #project_name為你的項目名 執行完后項目結構如圖所示 然…

同等學力申碩專業介紹——教育學碩士

同等學力申碩的專業很多。 目前有十三大門類&#xff0c;分別是醫學、法學、管理學、工學、教育學、經濟學、藝術學、文學、歷史學、理學、哲學、農學、軍事學等&#xff0c;每個大門類中都有很多的細分專業。 今天為大家介紹同等學力申碩專業——教育學。 專業介紹 教育學該…

基于java+springboot動物檢疫信息管理系統設計和實現

基于java SSM springboot動物檢疫信息管理系統設計和實現 博主介紹&#xff1a;多年java開發經驗&#xff0c;專注Java開發、定制、遠程、文檔編寫指導等,csdn特邀作者、專注于Java技術領域 作者主頁 央順技術團隊 Java畢設項目精品實戰案例《1000套》 歡迎點贊 收藏 ?留言 文…

【寸鐵的刷題筆記】樹、dfs、bfs、回溯、遞歸(三)

【寸鐵的刷題筆記】樹、dfs、bfs、回溯、遞歸(三) 大家好 我是寸鐵&#x1f44a; 金三銀四&#xff0c;樹、dfs、bfs、回溯、遞歸是必考的知識點? 快跟著寸鐵刷起來&#xff01;面試順利上岸&#x1f44b; 喜歡的小伙伴可以點點關注 &#x1f49d; 530. 二叉搜索樹的最小絕對差…

考研政治這樣復習更高效

政治復習是考研備考中的重要一環&#xff0c;需要考生制定科學的復習計劃&#xff0c;注重知識點的掌握和解題技巧的提升。以下是一些政治復習的建議&#xff1a; 梳理知識框架&#xff1a;首先&#xff0c;需要梳理政治學科的知識框架&#xff0c;了解各個章節之間的內在聯系…

【Vue3】自定義 Vue3 插件(全局實現頁面加載動畫)

// main.ts import { createApp } from vue import App from ./App.vue import Loading from "./components/Loading/index.ts";const app createApp(App) type Lod {show: () > void,hide: () > void } //編寫ts loading 聲明文件放置報錯 和 智能提示 decl…

python實現常見一元隨機變量的概率分布

一. 隨機變量 隨機變量是一個從樣本空間 Ω \Omega Ω到實數空間 R R R的函數&#xff0c;比如隨機變量 X X X可以表示投骰子的點數。隨機變量一般可以分為兩類&#xff1a; 離散型隨機變量&#xff1a;隨機變量的取值為有限個。連續型隨機變量&#xff1a;隨機變量的取值是連…

Redis 群集部署

1.關系型數據庫 關系型數據庫是一個結構化的數據庫&#xff0c;創建在關系模型基礎上&#xff0c;-般面向記錄。它借助于集合代數等數學概念和方法來處理數據庫中的數據。關系模型指二維表格模型,因而一個關系型數據庫就是由二維表及其之間的聯系組成的一個數據組織。現實世界中…