Get史上最優(yōu)雅加密方式撞羽!沒有之一诀紊!

使用方式

你的配置文件是不是還在使用下面這種落后的配置暴露一些密碼:

jdbc.url=jdbc:mysql://127.0.0.1:3305/afeidb
jdbc.username=afei
jdbc.password=123456

如果是隅俘,那么繼續(xù)往下看为居。筆者今天介紹史上最優(yōu)雅加密接入方式:jasypt

  • 用法一

先看用法有多簡單贰镣,以springboot為例:

  1. Application.java上增加注解@EnableEncryptableProperties;
  2. 增加配置文件jasypt.encryptor.password = Afei@2018恭陡,這是加密的秘鑰上煤;
  3. 所有明文密碼替換為ENC(加密字符串)劫狠,例如ENC(XW2daxuaTftQ+F2iYPQu0g==);
  4. 引入一個MAVEN依賴呐矾;

maven坐標(biāo)如下:

<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot</artifactId>
    <version>2.0.0</version>
</dependency>

簡答的4步就搞定啦凫佛,是不是超簡單愧薛?完全不需要修改任何業(yè)務(wù)代碼衫画。 其中第三步的加密字符串的生成方式為:
java -cp jasypt-1.9.2.jar org.jasypt.intf.cli.JasyptPBEStringEncryptionCLI input="123456" password=Afei@2018 algorithm=PBEWithMD5AndDES

其中:

  • input的值就是原密碼。
  • password的值就是參數(shù)jasypt.encryptor.password指定的值瞄勾,即秘鑰弥激。

  • 用法二

其實還有另一種更簡單的姿勢:

  1. 增加配置文件jasypt.encryptor.password = Afei@2018微服,這是加密的秘鑰以蕴;
  2. 所有明文密碼替換為ENC(加密字符串)糙麦,例如ENC(XW2daxuaTftQ+F2iYPQu0g==)赡磅;
  3. 引入一個MAVEN依賴焚廊;

maven坐標(biāo)如下:

<dependency>
    <groupId>com.github.ulisesbocchio</groupId>
    <artifactId>jasypt-spring-boot-starter</artifactId>
    <version>2.0.0</version>
</dependency>

相比第一種用法,maven坐標(biāo)有所變化徙硅。但是不需要顯示增加注解@EnableEncryptableProperties搞疗;

github地址

github:https://github.com/ulisesbocchio/jasypt-spring-boot
它github首頁有詳細的用法說明匿乃,以及一些自定義特性幢炸,例如使用自定義的前綴和后綴取代ENC():

jasypt.encryptor.property.prefix=ENC@[
jasypt.encryptor.property.suffix=]

原理解密

既然是springboot方式集成宛徊,那么首先看jasypt-spring-boot的spring.factories的申明:

org.springframework.context.ApplicationListener=\
com.ulisesbocchio.jasyptspringboot.configuration.EnableEncryptablePropertiesBeanFactoryPostProcessor

這個類的部分核心源碼如下:

public class EnableEncryptablePropertiesBeanFactoryPostProcessor implements BeanFactoryPostProcessor, ApplicationListener<ApplicationEvent>, Ordered {
    @Override
    public void postProcessBeanFactory(ConfigurableListableBeanFactory beanFactory) throws BeansException {
        // 得到加密字符串的處理類(已經(jīng)加密的密碼通過它來解密)
        EncryptablePropertyResolver propertyResolver = beanFactory.getBean(RESOLVER_BEAN_NAME, EncryptablePropertyResolver.class);
        // springboot下的Environment里包含了所有我們定義的屬性, 也就包含了application.properties中所有的屬性
        MutablePropertySources propSources = environment.getPropertySources();
        // 核心闸天,PropertySource的getProperty(String)方法委托給EncryptablePropertySourceWrapper
        convertPropertySources(interceptionMode, propertyResolver, propSources);
    }

    @Override
    public int getOrder() {
        // 讓這個jasypt定義的BeanFactoryPostProcessor的初始化順序最低苞氮,即最后初始化
        return Ordered.LOWEST_PRECEDENCE;
    }
}

PropertySource的getProperty(String)方法委托給EncryptablePropertySourceWrapper笼吟,那么當(dāng)獲取屬性時贷帮,實際上就是調(diào)用EncryptablePropertySourceWrapper的getProperty()方法诱告,在這個方法里我們就能對value進行解密了蔬啡。

EncryptablePropertySourceWrapper實現(xiàn)了接口EncryptablePropertyResolver诲侮,該定義如下:

// An interface to resolve property values that may be encrypted.
public interface EncryptablePropertyResolver {

    String resolvePropertyValue(String value);
}

接口描述:
Returns the unencrypted version of the value provided free on any prefixes/suffixes or any other metadata surrounding the encrypted value. Or the actual same String if no encryption was detected.

  • 如果通過prefixes/suffixes包裹的屬性,那么返回解密后的值箱蟆;
  • 如果沒有被包裹沟绪,那么返回原生的值;

實現(xiàn)類的實現(xiàn)如下:

@Override
public String resolvePropertyValue(String value) {
    String actualValue = value;
    // 如果value是加密的value空猜,則進行解密绽慈。
    if (detector.isEncrypted(value)) {
        try {
            // 解密算法核心實現(xiàn)
            actualValue = encryptor.decrypt(detector.unwrapEncryptedValue(value.trim()));
        } catch (EncryptionOperationNotPossibleException e) {
            // 如果解密失敗恨旱,那么拋出異常。
            throw new DecryptionException("Decryption of Properties failed,  make sure encryption/decryption passwords match", e);
        }
    }
    // 沒有加密的value坝疼,返回原生value即可
    return actualValue;
}

判斷是否是加密的邏輯很簡單:(trimmedValue.startsWith(prefix) && trimmedValue.endsWith(suffix))搜贤,即只要value是以prefixe/suffixe包括前酿,就認(rèn)為是加密的value培漏。

總結(jié)

通過對源碼的分析可知jasypt的原理很簡單晕鹊,就是講原本spring中PropertySource的getProperty(String)方法委托給我們自定義的實現(xiàn)盏触。然后再自定義實現(xiàn)中吓肋,判斷value是否是已經(jīng)加密的value哟沫,如果是猾警,則進行解密。如果不是雳窟,則返回原value捣作。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末也拜,一起剝皮案震驚了整個濱河市蔓钟,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌世分,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,284評論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件镐牺,死亡現(xiàn)場離奇詭異旗唁,居然都是意外死亡讶请,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,115評論 3 395
  • 文/潘曉璐 我一進店門丹禀,熙熙樓的掌柜王于貴愁眉苦臉地迎上來持搜,“玉大人薄扁,你說我怎么就攤上這事脱盲∫纯矗” “怎么了尚卫?”我有些...
    開封第一講書人閱讀 164,614評論 0 354
  • 文/不壞的土叔 我叫張陵特石,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么玖姑? 我笑而不...
    開封第一講書人閱讀 58,671評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮缴川,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘岂膳。我一直安慰自己知市,他們只是感情好规哲,可當(dāng)我...
    茶點故事閱讀 67,699評論 6 392
  • 文/花漫 我一把揭開白布秃症。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上蒋失,一...
    開封第一講書人閱讀 51,562評論 1 305
  • 那天,我揣著相機與錄音铣卡,去河邊找鬼。 笑死蝉仇,一個胖子當(dāng)著我的面吹牛轿衔,可吹牛的內(nèi)容都是我干的宛官。 我是一名探鬼主播,決...
    沈念sama閱讀 40,309評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了瞧掺?” 一聲冷哼從身側(cè)響起壹蔓,我...
    開封第一講書人閱讀 39,223評論 0 276
  • 序言:老撾萬榮一對情侶失蹤趟妥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后庶溶,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體煮纵,經(jīng)...
    沈念sama閱讀 45,668評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,859評論 3 336
  • 正文 我和宋清朗相戀三年偏螺,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片匆光。...
    茶點故事閱讀 39,981評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡套像,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出终息,到底是詐尸還是另有隱情夺巩,我是刑警寧澤,帶...
    沈念sama閱讀 35,705評論 5 347
  • 正文 年R本政府宣布周崭,位于F島的核電站柳譬,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏续镇。R本人自食惡果不足惜美澳,卻給世界環(huán)境...
    茶點故事閱讀 41,310評論 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧制跟,春花似錦舅桩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,904評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至聊记,卻和暖如春撒妈,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背排监。 一陣腳步聲響...
    開封第一講書人閱讀 33,023評論 1 270
  • 我被黑心中介騙來泰國打工狰右, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人社露。 一個月前我還...
    沈念sama閱讀 48,146評論 3 370
  • 正文 我出身青樓挟阻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親峭弟。 傳聞我的和親對象是個殘疾皇子附鸽,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,933評論 2 355