




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報或認(rèn)領(lǐng)
文檔簡介
第SpringBoot整合jasypt實現(xiàn)敏感信息的加密詳解目錄一、簡介二、導(dǎo)入依賴三、加密字段工具類四、application.yaml配置五、啟動類測試
一、簡介
在后端開發(fā)中有很多敏感信息,比如數(shù)據(jù)庫用戶名密碼,第三方Apikey,云服務(wù)商的secretKey等、如果不希望用明文在application.yml配置的,可以使用jasypt加密這些字段。
還有很重要的一點,如果你自己開源一些東西,將代碼上傳一些代碼托管平臺,肯定需要隱藏敏感信息,用jasypt加密可以簡化每次上傳下拉代碼修改敏感信息。
官方文檔,官方文檔使用方法描述得很清楚適用于各種情況,下面我簡單記錄一下加密MySQL用戶名密碼方法
二、導(dǎo)入依賴
dependencies
!--jasypt敏感數(shù)據(jù)加密,如:數(shù)據(jù)庫密碼,阿里云短信服務(wù)等--
dependency
groupIdcom.github.ulisesbocchio/groupId
artifactIdjasypt-spring-boot-starter/artifactId
version3.0.4/version
/dependency
!--mysql--
dependency
groupIdmysql/groupId
artifactIdmysql-connector-java/artifactId
version8.0.30/version
scoperuntime/scope
/dependency
!--mybatis-plus--
dependency
groupIdcom.baomidou/groupId
artifactIdmybatis-plus-boot-starter/artifactId
version3.5.2/version
/dependency
!--springboot啟動包--
dependency
groupIdorg.springframework.boot/groupId
artifactIdspring-boot-starter/artifactId
/dependency
/dependencies
三、加密字段工具類
加密mysql用戶名密碼,將用戶名密碼傳入fields數(shù)組,保存打印結(jié)果下面配置在application.yaml文件
publicclassJasyptUtil{
privatestaticPooledPBEStringEncryptorencryptor;
static{
encryptor=newPooledPBEStringEncryptor();
SimpleStringPBEConfigconfig=newSimpleStringPBEConfig();
config.setPassword("Thisisasecretkey");//秘鑰
config.setAlgorithm("PBEWithMD5AndDES");
//config.setAlgorithm("PBEWITHHMACSHA512ANDAES_256");
config.setKeyObtentionIterations("1000");
config.setPoolSize("1");
config.setProviderName("SunJCE");
config.setSaltGeneratorClassName("org.jasypt.salt.RandomSaltGenerator");
config.setIvGeneratorClassName("org.jasypt.iv.RandomIvGenerator");
config.setStringOutputType("base64");
encryptor.setConfig(config);
publicstaticvoidmain(String[]args){
//需要加密的字段
String[]fields={"root","123456"};
for(Stringfield:fields){
System.out.println(field+"----"+encryptorField(field));
publicstaticStringencryptorField(Stringfield){
returnencryptor.encrypt(field);
publicstaticStringdecryptField(Stringfield){
returnencryptor.decrypt(field);
}
可以看到加密過后的字符串如下
四、application.yaml配置
數(shù)據(jù)源用戶名密碼使用上面生成加密字段
spring:
datasource:
username:ENC(J5GOvO1FBgtiwEytIjU/4WdzHUgbJq/W)
password:ENC(SqCHgntWcYnthvtWGA3+GAycDle/qCBx)
driver-class-name:com.mysql.cj.jdbc.Driver
url:jdbc:mysql://localhost:3306/oauthserverTimezone=UTCuseUnicode=truecharacterEncoding=utf8
#jasypt敏感數(shù)據(jù)加密配置
#詳細(xì)用法可參考/ulisesbocchio/jasypt-spring-boot
jasypt:
encryptor:
password:123456#秘鑰,除了該項,下面都是默認(rèn)值,該項建議設(shè)置JVM啟動參數(shù),如:-Djasypt.encryptor.password=123456
algorithm:PBEWithMD5AndDES#加密算法
key-obtention-iterations:1000#迭代次數(shù),值越大越復(fù)雜,相對越安全
pool-size:1
provider-name:SunJCE
salt-generator-classname:org.jasypt.salt.RandomSaltGenerator
iv-generator-classname:org.jasypt.iv.RandomIvGenerator
string-output-type:base64
proxy-property-sources:false
property:
prefix:ENC(#默認(rèn)前綴
suffix:)#默認(rèn)后綴
五、啟動類測試
查詢MySQL的user表打印用戶名和密碼
packagecom.ye;
importorg.springframework.boot.SpringApplication;
importorg.springframework.boot.autoconfigure.SpringBootApplication;
importorg.springframework.context.ConfigurableApplicationContext;
importjavax.sql.DataSource;
importjava.sql.Connection;
importjava.sql.PreparedStatement;
importjava.sql.ResultSet;
importjava.sql.SQLException;
@SpringBootApplication
publicclassTest2Application{
publicstaticvoidmain(String[]args)throwsSQLException{
ConfigurableApplicationContextcontext=SpringApplication.run(Test2Application.class,args);
DataSourcedataSource=(DataSource)context.getBean("dataSource");
Connectionconnection=dataSource.getConnection();
try{
PreparedStatementps=connection.prepareStatement("select*fromuser;");
ResultSetrs=ps.executeQuery();
System.out.println("----------user表數(shù)據(jù)-----------
while(rs.next()){
StringuserName=rs.getString("user_name");
Stringpassword=rs.getString("password");
System.out.printf("userName:%s,password:%s%n",userName,password);
}catch(SQLException
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 能源企業(yè)部分股權(quán)轉(zhuǎn)讓及新能源項目合作協(xié)議
- 文化活動場地租賃合同終止及場地恢復(fù)協(xié)議
- 商業(yè)保險理賠與財產(chǎn)分配合同
- 高端離婚子女撫養(yǎng)及財產(chǎn)分割協(xié)議
- 政府機構(gòu)公務(wù)車輛無償租賃使用協(xié)議
- 車輛事故責(zé)任承擔(dān)及經(jīng)濟(jì)賠償協(xié)議范本
- 精裝修住宅出租服務(wù)合同
- 北京科萬物業(yè)裝修工程合同施工安全與質(zhì)量保障協(xié)議
- 酒店培訓(xùn)服務(wù)禮儀
- 2024年高考語文備考之掌握分析高考古詩題材技巧
- 2024-2025學(xué)年下學(xué)期高一化學(xué)蘇教版期末必刷??碱}之原電池與電解池
- 公司系統(tǒng)主數(shù)據(jù)管理制度
- 2025年煙臺市中考地理試卷真題(含答案及解析)
- 工廠安全手冊從火災(zāi)到其他事故的應(yīng)急響應(yīng)
- 肯德基服務(wù)管理制度
- 2025至2030中國微晶玻璃行業(yè)產(chǎn)業(yè)運行態(tài)勢及投資規(guī)劃深度研究報告
- 部編版二年級語文下冊期末測試卷(含答案)
- 抖音精準(zhǔn)圈層種草
- 300MW單元機組過熱汽溫控制系統(tǒng)的設(shè)計
- (完整版)銷售人員銷售能力測試及答案解析
- 橋架、線槽支架重量計算表
評論
0/150
提交評論