java如何對字符串進(jìn)行加密 ?

如題, 下面是lz使用java內(nèi)置的DES算法進(jìn)行的加密算法, 希望對你有用


import java.security.Key;

import javax.crypto.Cipher;

/**
 * 使用DES算法對字符串進(jìn)行加密解密 (加密解密的操作步驟正好相反, 參考 {@link #encrypt(String)}, {@link #decrypt(String)})
 */
public class DesUtils {
    private static String defaultSecretKey = "default_secret_key"; //默認(rèn)密鑰
    private Cipher encryptCipher = null; //加密器
    private Cipher decryptCipher = null; //解密器

    public DesUtils() throws Exception {
        this(defaultSecretKey);
    }

    /**
     * @param secretKey 加密解密使用的密鑰
     */
    public DesUtils(String secretKey) {
        Key key;
        try {
            key = getKey(secretKey.getBytes());
            encryptCipher = Cipher.getInstance("DES");
            encryptCipher.init(Cipher.ENCRYPT_MODE, key);
            decryptCipher = Cipher.getInstance("DES");
            decryptCipher.init(Cipher.DECRYPT_MODE, key);
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

    /**
     * 加密 (邏輯: 1. 將要加密的字符串轉(zhuǎn)換為字節(jié)數(shù)組(byte array)<br/>
     *            2. 將第一步的字節(jié)數(shù)組作為輸入使用加密器(Cipher)的doFinal方法進(jìn)行加密, 返回字節(jié)數(shù)組<br/>
     *            3. 把加密后的字節(jié)數(shù)組轉(zhuǎn)換成十六進(jìn)制的字符串)<br/>
     * @param strIn 要加密的字符串
     * @return 返回加密后的十六進(jìn)制字符串
     * @throws Exception
     */
    public String encrypt(String strIn) throws Exception {
        return byteArr2HexStr(encrypt(strIn.getBytes()));
    }

    public byte[] encrypt(byte[] arrB) throws Exception {
        return encryptCipher.doFinal(arrB);
    }

    /**
     * 解密 (邏輯: 1. 把加密后的十六進(jìn)制字符串轉(zhuǎn)換成字節(jié)數(shù)組(byte array)<br/>
     *            2. 將第一步的字節(jié)數(shù)組作為輸入使用加密器(Cipher)的doFinal方法進(jìn)行解密, 返回字節(jié)數(shù)組(byte array)<br/>
     *            3. 把解密后的字節(jié)數(shù)組轉(zhuǎn)換成字符串)<br/>
     * @param strIn
     * @return
     * @throws Exception
     */
    public String decrypt(String strIn) throws Exception {
        return new String(decrypt(hexStr2ByteArr(strIn)));
    }

    public byte[] decrypt(byte[] arrB) throws Exception {
        return decryptCipher.doFinal(arrB);
    }

    public static String byteArr2HexStr(byte[] arrB) throws Exception {
        int iLen = arrB.length;
        // 每個byte用兩個字符才能表示,所以字符串的長度是數(shù)組長度的兩倍
        StringBuffer sb = new StringBuffer(iLen * 2);
        for (int i = 0; i < iLen; i++) {
            int intTmp = arrB[i];
            // 把負(fù)數(shù)轉(zhuǎn)換為正數(shù)
            while (intTmp < 0) {
                intTmp = intTmp + 256;
            }
            // 小于0F的數(shù)需要在前面補(bǔ)0
            if (intTmp < 16) {
                sb.append("0");
            }
            sb.append(Integer.toString(intTmp, 16));
        }
        return sb.toString();
    }

    public static byte[] hexStr2ByteArr(String strIn) throws Exception {
        byte[] arrB = strIn.getBytes();
        int iLen = arrB.length;
        // 兩個字符表示一個字節(jié)簇搅,所以字節(jié)數(shù)組長度是字符串長度除以2
        byte[] arrOut = new byte[iLen / 2];
        for (int i = 0; i < iLen; i = i + 2) {
            String strTmp = new String(arrB, i, 2);
            arrOut[i / 2] = (byte) Integer.parseInt(strTmp, 16);
        }
        return arrOut;
    }

    private Key getKey(byte[] arrBTmp) throws Exception {
        // 創(chuàng)建一個空的8位字節(jié)數(shù)組(默認(rèn)值為0)
        byte[] arrB = new byte[8];
        // 將原始字節(jié)數(shù)組轉(zhuǎn)換為8位
        for (int i = 0; i < arrBTmp.length && i < arrB.length; i++) {
            arrB[i] = arrBTmp[i];
        }
        // 生成密鑰
        Key key = new javax.crypto.spec.SecretKeySpec(arrB, "DES");
        return key;
    }


    /**
     * 用法實例
     */
    public static void main(String[] args) {
        try {
            String test = "liwc";
            //注意這里,自定義的加密的KEY要和解密的KEY一致晃痴,這就是鑰匙,如果你上鎖了寝蹈,卻忘了鑰匙垦江,那么是解密不了的
            DesUtils des = new DesUtils("leemenz"); //自定義密鑰
            System.out.println("加密前的字符:" + test);
            System.out.println("加密后的字符:" + des.encrypt(test));
            System.out.println("解密后的字符:" + des.decrypt(des.encrypt(test)));
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市睡扬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌黍析,老刑警劉巖卖怜,帶你破解...
    沈念sama閱讀 218,607評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異阐枣,居然都是意外死亡马靠,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,239評論 3 395
  • 文/潘曉璐 我一進(jìn)店門蔼两,熙熙樓的掌柜王于貴愁眉苦臉地迎上來甩鳄,“玉大人,你說我怎么就攤上這事额划∶羁校” “怎么了?”我有些...
    開封第一講書人閱讀 164,960評論 0 355
  • 文/不壞的土叔 我叫張陵俊戳,是天一觀的道長揖赴。 經(jīng)常有香客問我,道長抑胎,這世上最難降的妖魔是什么燥滑? 我笑而不...
    開封第一講書人閱讀 58,750評論 1 294
  • 正文 為了忘掉前任,我火速辦了婚禮圆恤,結(jié)果婚禮上突倍,老公的妹妹穿的比我還像新娘。我一直安慰自己盆昙,他們只是感情好羽历,可當(dāng)我...
    茶點故事閱讀 67,764評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著淡喜,像睡著了一般秕磷。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上炼团,一...
    開封第一講書人閱讀 51,604評論 1 305
  • 那天澎嚣,我揣著相機(jī)與錄音,去河邊找鬼瘟芝。 笑死易桃,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的锌俱。 我是一名探鬼主播晤郑,決...
    沈念sama閱讀 40,347評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼贸宏!你這毒婦竟也來了造寝?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,253評論 0 276
  • 序言:老撾萬榮一對情侶失蹤吭练,失蹤者是張志新(化名)和其女友劉穎诫龙,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體鲫咽,經(jīng)...
    沈念sama閱讀 45,702評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡签赃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,893評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了分尸。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片姊舵。...
    茶點故事閱讀 40,015評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖寓落,靈堂內(nèi)的尸體忽然破棺而出括丁,到底是詐尸還是另有隱情,我是刑警寧澤伶选,帶...
    沈念sama閱讀 35,734評論 5 346
  • 正文 年R本政府宣布史飞,位于F島的核電站,受9級特大地震影響仰税,放射性物質(zhì)發(fā)生泄漏构资。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,352評論 3 330
  • 文/蒙蒙 一陨簇、第九天 我趴在偏房一處隱蔽的房頂上張望吐绵。 院中可真熱鬧,春花似錦、人聲如沸己单。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,934評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽纹笼。三九已至纹份,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間廷痘,已是汗流浹背蔓涧。 一陣腳步聲響...
    開封第一講書人閱讀 33,052評論 1 270
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留笋额,地道東北人元暴。 一個月前我還...
    沈念sama閱讀 48,216評論 3 371
  • 正文 我出身青樓,卻偏偏與公主長得像兄猩,于是被迫代替她去往敵國和親昨寞。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,969評論 2 355

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