Java AES加/解密 + Base64編/解碼

1.AES 密鑰+偏移進(jìn)行加密解密 結(jié)合 base64對加密之后的字節(jié)數(shù)組進(jìn)行編碼解碼(代碼如下)

最近項目上需要用到數(shù)據(jù)加密存儲窄潭,查詢資料后發(fā)現(xiàn)目前AES加密安全度非常高,具體原理可自行百度冠王。但經(jīng)網(wǎng)上搜到的實(shí)現(xiàn)示例運(yùn)行都有各種問題米丘,耗時一上午剑令,終于調(diào)試運(yùn)行成功,閑話少說拄查,直接上代碼吁津。
參考gfaming的博客

import javax.crypto.Cipher;  
import javax.crypto.spec.IvParameterSpec;  
import javax.crypto.spec.SecretKeySpec;  
  
import sun.misc.BASE64Decoder;  
import sun.misc.BASE64Encoder;  
  
public class AesEncodeUtil {  
  
    //初始向量(偏移)  
    public static final String VIPARA = "aabbccddeeffgghh";   //AES 為16bytes. DES 為8bytes  
      
    //編碼方式  
    public static final String bm = "UTF-8";  
      
    //私鑰  (密鑰)
    private static final String ASE_KEY="aabbccddeeffgghh";   //AES固定格式為128/192/256 bits.即:16/24/32bytes。DES固定格式為128bits堕扶,即8bytes碍脏。  
      
    /** 
     * 加密 
     *  
     * @param cleartext 加密前的字符串
     * @return 加密后的字符串
     */  
    public static String encrypt(String cleartext) {  
      
        //------------------------------------------AES加密-------------------------------------

        //加密方式: AES128(CBC/PKCS5Padding) + Base64, 私鑰:aabbccddeeffgghh  
        try {  
            IvParameterSpec zeroIv = new IvParameterSpec(VIPARA.getBytes());  
            //兩個參數(shù),第一個為私鑰字節(jié)數(shù)組稍算, 第二個為加密方式 AES或者DES  
            SecretKeySpec key = new SecretKeySpec(ASE_KEY.getBytes(), "AES");  
            //實(shí)例化加密類典尾,參數(shù)為加密方式,要寫全  
            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding"); //PKCS5Padding比PKCS7Padding效率高糊探,PKCS7Padding可支持IOS加解密  
             //初始化钾埂,此方法可以采用三種方式河闰,按加密算法要求來添加。(1)無第三個參數(shù)(2)第三個參數(shù)為SecureRandom random = new SecureRandom();中random對象勃教,隨機(jī)數(shù)淤击。(AES不可采用這種方法)(3)采用此代碼中的IVParameterSpec  
            cipher.init(Cipher.ENCRYPT_MODE, key, zeroIv);  

             //------------------------------------------base64編碼-------------------------------------

            //加密操作,返回加密后的字節(jié)數(shù)組,然后需要編碼故源。主要編解碼方式有Base64, HEX, UUE,7bit等等污抬。此處看服務(wù)器需要什么編碼方式  
            //byte[] encryptedData = cipher.doFinal(cleartext.getBytes(bm));  
            //return new BASE64Encoder().encode(encryptedData);  

             //上下等同,只是導(dǎo)入包不同

             //加密后的字節(jié)數(shù)組
            byte[] encryptedData = cipher.doFinal(cleartext.getBytes(bm));
            //對加密后的字節(jié)數(shù)組進(jìn)行base64編碼
            byte[] base64Data = org.apache.commons.codec.binary.Base64.encodeBase64(encryptedData);
            //將base64編碼后的字節(jié)數(shù)組轉(zhuǎn)化為字符串并返回
            return new String(base64Data);

            //------------------------------------------/base64編碼-------------------------------------

        } catch (Exception e) {  
            e.printStackTrace();  
            return "";   
        }  
       //------------------------------------------/AES加密-------------------------------------
    }  
  
    /** 
     * 解密 
     *  
     * @param encrypted 解密前的字符串(也就是加密后的字符串)
     * @return 解密后的字符串(也就是加密前的字符串)
     */  
    public static String decrypt(String encrypted) {  

        //---------------------------------------AES解密----------------------------------------

        try {  

            //---------------------------------------base64解碼---------------------------------------

            //byte[] byteMi = new BASE64Decoder().decodeBuffer(encrypted); 
 
            //上下等同绳军,只是導(dǎo)入包不同

            //將字符串轉(zhuǎn)化為base64編碼的字節(jié)數(shù)組
            byte[] encryptedBase64Bytes = encrypted.getBytes();
            //將base64編碼的字節(jié)數(shù)組轉(zhuǎn)化為在加密之后的字節(jié)數(shù)組
            byte[] byteMi = org.apache.commons.codec.binary.Base64.decodeBase64(encryptedBase64Bytes);

           //---------------------------------------/base64解碼---------------------------------------
     
            IvParameterSpec zeroIv = new IvParameterSpec(VIPARA.getBytes());  
            SecretKeySpec key = new SecretKeySpec(  
                    ASE_KEY.getBytes(), "AES");  
            Cipher cipher = Cipher.getInstance("AES/CBC/PKCS5Padding");  
            //與加密時不同MODE:Cipher.DECRYPT_MODE  
            cipher.init(Cipher.DECRYPT_MODE, key, zeroIv);  
            byte[] decryptedData = cipher.doFinal(byteMi);  
            return new String(decryptedData, bm);  
        } catch (Exception e) {  
            e.printStackTrace();  
            return "";  
        }  
       //---------------------------------------/AES解密----------------------------------------
    }  
  
    /** 
     * 測試 
     *  
     * @param args 
     * @throws Exception 
     */  
    public static void main(String[] args) throws Exception {  
  
  
        String content = "98.5674";  
        // 加密  
        System.out.println("加密前:" + content);  
        String encryptResult = encrypt(content);  
          
        System.out.println("加密后:" + new String(encryptResult));  
        // 解密  
        String decryptResult = decrypt(encryptResult);  
        System.out.println("解密后:" + new String(decryptResult));  
  
  
    }  
}  

學(xué)習(xí)AES加密的一些文章:
1.JAVA實(shí)現(xiàn)AES加密

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末印机,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子门驾,更是在濱河造成了極大的恐慌射赛,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,544評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件奶是,死亡現(xiàn)場離奇詭異楣责,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)聂沙,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,430評論 3 392
  • 文/潘曉璐 我一進(jìn)店門秆麸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人及汉,你說我怎么就攤上這事沮趣。” “怎么了坷随?”我有些...
    開封第一講書人閱讀 162,764評論 0 353
  • 文/不壞的土叔 我叫張陵房铭,是天一觀的道長。 經(jīng)常有香客問我温眉,道長缸匪,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,193評論 1 292
  • 正文 為了忘掉前任凌蔬,我火速辦了婚禮豌骏,結(jié)果婚禮上隐锭,老公的妹妹穿的比我還像新娘钦睡。我一直安慰自己,他們只是感情好洒琢,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,216評論 6 388
  • 文/花漫 我一把揭開白布衰抑。 她就那樣靜靜地躺著,像睡著了一般砾淌。 火紅的嫁衣襯著肌膚如雪谭网。 梳的紋絲不亂的頭發(fā)上愉择,一...
    開封第一講書人閱讀 51,182評論 1 299
  • 那天锥涕,我揣著相機(jī)與錄音衷戈,去河邊找鬼站楚。 笑死,一個胖子當(dāng)著我的面吹牛拉一,可吹牛的內(nèi)容都是我干的旧乞。 我是一名探鬼主播,決...
    沈念sama閱讀 40,063評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼嫡纠,長吁一口氣:“原來是場噩夢啊……” “哼延赌!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起挫以,我...
    開封第一講書人閱讀 38,917評論 0 274
  • 序言:老撾萬榮一對情侶失蹤掐松,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后探膊,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體待榔,經(jīng)...
    沈念sama閱讀 45,329評論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡猾担,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,543評論 2 332
  • 正文 我和宋清朗相戀三年绑嘹,在試婚紗的時候發(fā)現(xiàn)自己被綠了橘茉。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,722評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡擅腰,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出翁潘,到底是詐尸還是另有隱情趁冈,我是刑警寧澤拜马,帶...
    沈念sama閱讀 35,425評論 5 343
  • 正文 年R本政府宣布,位于F島的核電站俩莽,受9級特大地震影響旺坠,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜扮超,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,019評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望出刷。 院中可真熱鬧璧疗,春花似錦、人聲如沸馁龟。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,671評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽啦膜。三九已至僧家,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間八拱,已是汗流浹背肌稻。 一陣腳步聲響...
    開封第一講書人閱讀 32,825評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留爹谭,地道東北人诺凡。 一個月前我還...
    沈念sama閱讀 47,729評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像践惑,于是被迫代替她去往敵國和親腹泌。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,614評論 2 353

推薦閱讀更多精彩內(nèi)容