laoding
          本來我以為,隱身了別人就找不到我,沒有用的,像我這樣拉風(fēng)的男人,無論走到哪里,都像在黑暗中的螢火蟲一樣,那樣的鮮明,那樣的出眾。我那憂郁的眼神,稀疏的胡茬,那微微隆起的將軍肚和親切的笑容......都深深吸引了眾人......
          posts - 0,  comments - 37,  trackbacks - 0
          這個我是在學(xué)習(xí)開發(fā)視頻的時候?qū)W習(xí)到的,分享給大家,就一個類

          import java.security.Key;
          import java.security.Security;

          import javax.crypto.Cipher;

          /**
           * @author aujlure
           * 加密解密
           */
          public class DESPlus {
           private static String strDefaultKey = "hilor"; //默認(rèn)密鑰

           private Cipher encryptCipher = null;

           private Cipher decryptCipher = null;

           /**
            * 將byte數(shù)組轉(zhuǎn)換為表示16進制值的字符串, 如:byte[]{8,18}轉(zhuǎn)換為:0813, 和public static byte[]
            * hexStr2ByteArr(String strIn) 互為可逆的轉(zhuǎn)換過程
            *
            * @param arrB
            *            需要轉(zhuǎn)換的byte數(shù)組
            * @return 轉(zhuǎn)換后的字符串
            * @throws Exception
            *             本方法不處理任何異常,所有異常全部拋出
            */
           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ù)需要在前面補0
             if (intTmp < 16) {
              sb.append("0");
             }
             sb.append(Integer.toString(intTmp, 16));
            }
            return sb.toString();
           }

           /**
            * 將表示16進制值的字符串轉(zhuǎn)換為byte數(shù)組, 和public static String byteArr2HexStr(byte[] arrB)
            * 互為可逆的轉(zhuǎn)換過程
            *
            * @param strIn
            *            需要轉(zhuǎn)換的字符串
            * @return 轉(zhuǎn)換后的byte數(shù)組
            * @throws Exception
            *             本方法不處理任何異常,所有異常全部拋出
            * @author <a href="mailto:leo841001@163.com">LiGuoQing</a>
            */
           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;
           }

           /**
            * 默認(rèn)構(gòu)造方法,使用默認(rèn)密鑰
            *
            * @throws Exception
            */
           public DESPlus() throws Exception {
            this(strDefaultKey);
           }

           /**
            * 指定密鑰構(gòu)造方法
            *
            * @param strKey
            *            指定的密鑰
            * @throws Exception
            */
           public DESPlus(String strKey) throws Exception {
            Security.addProvider(new com.sun.crypto.provider.SunJCE());
            Key key = getKey(strKey.getBytes());

            encryptCipher = Cipher.getInstance("DES");
            encryptCipher.init(Cipher.ENCRYPT_MODE, key);

            decryptCipher = Cipher.getInstance("DES");
            decryptCipher.init(Cipher.DECRYPT_MODE, key);
           }

           /**
            * 加密字節(jié)數(shù)組
            *
            * @param arrB
            *            需加密的字節(jié)數(shù)組
            * @return 加密后的字節(jié)數(shù)組
            * @throws Exception
            */
           public byte[] encrypt(byte[] arrB) throws Exception {
            return encryptCipher.doFinal(arrB);
           }

           /**
            * 加密字符串
            *
            * @param strIn
            *            需加密的字符串
            * @return 加密后的字符串
            * @throws Exception
            */
           public String encrypt(String strIn) throws Exception {
            return byteArr2HexStr(encrypt(strIn.getBytes()));
           }

           /**
            * 解密字節(jié)數(shù)組
            *
            * @param arrB
            *            需解密的字節(jié)數(shù)組
            * @return 解密后的字節(jié)數(shù)組
            * @throws Exception
            */
           public byte[] decrypt(byte[] arrB) throws Exception {
            return decryptCipher.doFinal(arrB);
           }

           /**
            * 解密字符串
            *
            * @param strIn
            *            需解密的字符串
            * @return 解密后的字符串
            * @throws Exception
            */
           public String decrypt(String strIn) throws Exception {
            return new String(decrypt(hexStr2ByteArr(strIn)));
           }

           /**
            * 從指定字符串生成密鑰,密鑰所需的字節(jié)數(shù)組長度為8位 不足8位時后面補0,超出8位只取前8位
            *
            * @param arrBTmp
            *            構(gòu)成該字符串的字節(jié)數(shù)組
            * @return 生成的密鑰
            * @throws java.lang.Exception
            */
           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) {

            String test = "username";
            // DESPlus des = new DESPlus();//默認(rèn)密鑰
            DESPlus des;
            try {
             des = new DESPlus();
             // 自定義密鑰
             System.out.println("加密前的字符:" + test);
             System.out.println("加密后的字符:" + des.encrypt(test));
             System.out.println("解密后的字符:" + des.decrypt(des.encrypt(test)));
            } catch (Exception e) {
             e.printStackTrace();
            }

           }
          }



          執(zhí)行它得到結(jié)果

          加密前的字符:username
          加密后的字符:3ffb671a8d90eae781ecf06918e2cd5f
          解密后的字符:username


          OK,加密解密完成
          posted on 2008-09-09 14:57 老丁 閱讀(426) 評論(0)  編輯  收藏 所屬分類: 加密技術(shù)

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          本博客主為學(xué)習(xí)和復(fù)習(xí)之用,無關(guān)其他,想罵人的繞道
          Email:dkm123456@126.com
          大家一起交流進步
          QQ:283582761


          <2025年5月>
          27282930123
          45678910
          11121314151617
          18192021222324
          25262728293031
          1234567

          留言簿(4)

          我參與的團隊

          文章分類(50)

          文章檔案(48)

          相冊

          朋友

          搜索

          •  

          積分與排名

          • 積分 - 96533
          • 排名 - 600

          最新評論

          主站蜘蛛池模板: 平湖市| 新河县| 淳安县| 四川省| 德州市| 公安县| 安西县| 焉耆| 桐庐县| 竹山县| 杭州市| 台东市| 石首市| 丹东市| 石景山区| 藁城市| 济南市| 沽源县| 平乐县| 承德市| 沈丘县| 冕宁县| 舟曲县| 句容市| 汶川县| 洛南县| 山东| 绥芬河市| 福建省| 绩溪县| 连江县| 瑞金市| 缙云县| 西华县| 汝南县| 深州市| 雅江县| 东阳市| 志丹县| 鄂州市| 淮安市|