好好生活,努力工作,天天向上!

          BlogJava 首頁 新隨筆 聯系 聚合 管理
            46 Posts :: 1 Stories :: 178 Comments :: 0 Trackbacks

             最近在做一個自動登錄的功能,要求在特定的條件下系統能夠自動的重啟,然后自動登錄,這就會涉及到用戶登錄信息緩存的問題,我們是基于Eclipse RCP框架,可以偷個懶,就使用Eclipse的屬性文件緩存,當然也可以使用二進制文件保存,由于以前就提供了記錄用戶上次的登錄用戶名和登錄的機構,這里只需要緩存密碼,將密碼明文保存到XML文件肯定不安全,保存成二進制文件中也不安全,比如123序列化保存到文件變成了495051,如果用戶真的很無聊而且懂點編程知識,可能會被破譯,所以從網上看了一個字符串加密解密的算法,很不錯,稍微修改了下,推薦給大家:

          package com.cnex.oss.framework.core.utils;

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

          import javax.crypto.Cipher;

          /**
           * DES加密和解密工具,可以對字符串進行加密和解密操作  。 
           * 
          @author 劉堯興
           * <p>2009-12-5</p>
           
          */
          public class DesUtils {
            
            
          /** 字符串默認鍵值     */
            
          private static String strDefaultKey = "national";

            
          /** 加密工具     */
            
          private Cipher encryptCipher = null;

            
          /** 解密工具     */
            
          private Cipher decryptCipher = null;

            
          /**  
             * 將byte數組轉換為表示16進制值的字符串, 如:byte[]{8,18}轉換為:0813, 和public static byte[]  
             * hexStr2ByteArr(String strIn) 互為可逆的轉換過程  
             *   
             * 
          @param arrB  
             *            需要轉換的byte數組  
             * 
          @return 轉換后的字符串  
             * 
          @throws Exception  
             *             本方法不處理任何異常,所有異常全部拋出  
             
          */
            
          public static String byteArr2HexStr(byte[] arrB) throws Exception {
              
          int iLen = arrB.length;
              
          // 每個byte用兩個字符才能表示,所以字符串的長度是數組長度的兩倍   
              StringBuffer sb = new StringBuffer(iLen * 2);
              
          for (int i = 0; i < iLen; i++) {
                
          int intTmp = arrB[i];
                
          // 把負數轉換為正數   
                while (intTmp < 0) {
                  intTmp 
          = intTmp + 256;
                }
                
          // 小于0F的數需要在前面補0   
                if (intTmp < 16) {
                  sb.append(
          "0");
                }
                sb.append(Integer.toString(intTmp, 
          16));
              }
              
          return sb.toString();
            }

            
          /**  
             * 將表示16進制值的字符串轉換為byte數組, 和public static String byteArr2HexStr(byte[] arrB)  
             * 互為可逆的轉換過程  
             *   
             * 
          @param strIn  
             *            需要轉換的字符串  
             * 
          @return 轉換后的byte數組  
             * 
          @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;

              
          // 兩個字符表示一個字節,所以字節數組長度是字符串長度除以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;
            }

            
          /**  
             * 默認構造方法,使用默認密鑰  
             *   
             * 
          @throws Exception  
             
          */
            
          public DesUtils() throws Exception {
              
          this(strDefaultKey);
            }

            
          /**  
             * 指定密鑰構造方法  
             *   
             * 
          @param strKey  
             *            指定的密鑰  
             * 
          @throws Exception  
             
          */
            
          public DesUtils(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);
            }

            
          /**  
             * 加密字節數組  
             *   
             * 
          @param arrB  
             *            需加密的字節數組  
             * 
          @return 加密后的字節數組  
             * 
          @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()));
            }

            
          /**  
             * 解密字節數組  
             *   
             * 
          @param arrB  
             *            需解密的字節數組  
             * 
          @return 解密后的字節數組  
             * 
          @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)));
            }

            
          /**  
             * 從指定字符串生成密鑰,密鑰所需的字節數組長度為8位 不足8位時后面補0,超出8位只取前8位  
             *   
             * 
          @param arrBTmp  
             *            構成該字符串的字節數組  
             * 
          @return 生成的密鑰  
             * 
          @throws java.lang.Exception  
             
          */
            
          private Key getKey(byte[] arrBTmp) throws Exception {
              
          // 創建一個空的8位字節數組(默認值為0)   
              byte[] arrB = new byte[8];

              
          // 將原始字節數組轉換為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;
            }

            
          /**
             * main方法  。
             * 
          @author 劉堯興
             * 
          @param args
             
          */
            
          public static void main(String[] args) {
              
          try {
                String test 
          = "123456789";
                DesUtils des 
          = new DesUtils("leemenz");//自定義密鑰   
                System.out.println("加密前的字符:" + test);
                System.out.println(
          "加密后的字符:" + des.encrypt(test));
                System.out.println(
          "解密后的字符:" + des.decrypt(des.encrypt(test)));
                
                System.out.println(
          "解密后的字符:" + des.decrypt("202cb962ac59075b964b07152d234b70"));
              }
              
          catch (Exception e) {
                e.printStackTrace();
              }
            }
          }
          本文來源于:http://www.icnote.com/DES-Encrypt/
          作者是:博愛老頭@博愛老頭的草屋
          真是非常感謝!
          posted on 2009-12-05 19:05 VWPOLO 閱讀(12484) 評論(4)  編輯  收藏 所屬分類: Java 技術

          Feedback

          # re: Java加密解密字符串[轉] 2012-07-18 09:39 路人
          昨天下午找了好多,也有你這個原版,不過也和你遇到一樣的問題,就是 System.out.println("解密后的字符:" + des.decrypt("202cb962ac59075b964b07152d234b70"));
          這個有問題。但是沒有解決,今天看了你的Ok了。  回復  更多評論
            

          # re: Java加密解密字符串[轉] 2013-10-28 20:14 2343243
          rer  回復  更多評論
            

          # re: Java加密解密字符串[轉][未登錄] 2014-05-06 16:51 li
          hu  回復  更多評論
            

          # re: Java加密解密字符串[轉] 2015-08-21 11:12 ewqreqw
          34123412341234134哩悲嘆框架在  回復  更多評論
            

          主站蜘蛛池模板: 高州市| 固阳县| 开江县| 南投市| 陇川县| 邯郸市| 沂源县| 特克斯县| 涿州市| 双鸭山市| 潍坊市| 盱眙县| 芷江| 瓮安县| 龙海市| 冀州市| 陆川县| 东阿县| 苗栗县| 无棣县| 金塔县| 吉水县| 莎车县| 逊克县| 错那县| 农安县| 鲁山县| 玉树县| 静乐县| 宜黄县| 富阳市| 汝南县| 宜章县| 临泽县| 屏东县| 江北区| 吉木萨尔县| 滨海县| 饶阳县| 垫江县| 胶南市|