<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

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

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

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

    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數(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];
          
    // 把負數(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;
      }

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

      
    /**  
       * 指定密鑰構(gòu)造方法  
       *   
       * 
    @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);
      }

      
    /**  
       * 加密字節(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ù)組(默認值為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;
      }

      
    /**
       * 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 閱讀(12481) 評論(4)  編輯  收藏 所屬分類: Java 技術(shù)

    Feedback

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

    # re: Java加密解密字符串[轉(zhuǎn)] 2013-10-28 20:14 2343243
    rer  回復(fù)  更多評論
      

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

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

    主站蜘蛛池模板: 国产精品区免费视频| 国产精品亚洲综合一区在线观看| 全黄A免费一级毛片| 九月婷婷亚洲综合在线| 国产精品亚洲一区二区在线观看| 免费黄色一级毛片| 国产成人人综合亚洲欧美丁香花| 国产免费69成人精品视频| 美女羞羞免费视频网站| 免费人成无码大片在线观看| 黄页网站在线免费观看| 亚洲色偷拍区另类无码专区| 久久免费99精品国产自在现线| 久久精品国产亚洲麻豆| 久久国产精品2020免费m3u8| 日韩精品一区二区亚洲AV观看| 永久免费在线观看视频| 亚洲a级片在线观看| 免费无码黄网站在线观看| 特级毛片aaaa级毛片免费| 中文国产成人精品久久亚洲精品AⅤ无码精品| 一个人看的免费观看日本视频www 一个人看的免费视频www在线高清动漫 | 叮咚影视在线观看免费完整版| 亚洲av成人无码久久精品| 免费在线视频你懂的| 亚洲av色香蕉一区二区三区 | 亚洲AV无码专区亚洲AV桃| 亚洲国产精品碰碰| 老司机69精品成免费视频| 91大神亚洲影视在线| 欧洲精品成人免费视频在线观看| 久久亚洲精品11p| 久久亚洲国产午夜精品理论片| 最近2019年免费中文字幕高清| 亚洲精品国产av成拍色拍| 国产亚洲精品影视在线产品| 久久久久高潮毛片免费全部播放| 亚洲人成电影网站色www| 亚洲熟妇av一区二区三区| 无码区日韩特区永久免费系列 | 亚洲成a人无码亚洲成www牛牛|