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

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

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

    隨筆 - 5, 文章 - 0, 評論 - 1, 引用 - 0
    數據加載中……

    DES算法簡單例程

    2.4 DES算法簡介
    DES即分組加密算法,明文密文都使用64位數據分組;采用對稱算法,加密和解密算法相同,但是使用的密鑰不同,密鑰使用56位數;由于算法只使用了簡單的數據邏輯和算術運算,所以實現起來相對簡單。本文就使用DES算法來給出一個加解密工具類。
    3.java 實現的對字符串加解密工具類
    import java.io.*;
    import javax.crypto.*;
    import javax.crypto.spec.*;
    import java.security.*;
    import java.security.spec.*;
    import com.sun.crypto.provider.SunJCE;
    import java.io.Serializable;

    /**
    * 提供加密算法,可以對輸入的字符串進行加密、解密操作
    */
    public class EncryptData
    {
    byte[] encryptKey;
    DESedeKeySpec spec;
    SecretKeyFactory keyFactory;
    SecretKey theKey;
    Cipher cipher;
    IvParameterSpec IvParameters;

    public EncryptData()
    {
    try
    {
    // 檢測是否有 TripleDES 加密的供應程序
    // 如無,明確地安裝SunJCE 供應程序
    try{ Cipher c = Cipher.getInstance("DESede"); }
    catch (Exception e)
    {
    System.err.println("Installling SunJCE provider.");
    Provider sunjce = new com.sun.crypto.provider.SunJCE();
    Security.addProvider(sunjce);
    }
    // 創建一個密鑰
    encryptKey = "This is a test DESede Key".getBytes();

    // 為上一密鑰創建一個指定的 DESSede key
    spec = new DESedeKeySpec(encryptKey);

    // 得到 DESSede keys
    keyFactory = SecretKeyFactory.getInstance("DESede");

    // 生成一個 DESede 密鑰對象
    theKey = keyFactory.generateSecret(spec);

    // 創建一個 DESede 密碼
    cipher = Cipher.getInstance("DESede/CBC/PKCS5Padding");

    // 為 CBC 模式創建一個用于初始化的 vector 對象
    IvParameters =
    new IvParameterSpec(new byte[]{12,34,56,78,90,87,65,43} );
    }
    catch (Exception exc)
    {
    // 記錄加密或解密操作錯誤
    }
    }

    /**
    * 加密算法
    * @param password 等待加密的密碼
    * @return 加密以后的密碼
    * @throws Exception
    */
    public byte[] encrypt(String password)
    {
    String encrypted_password = null;
    byte[] encrypted_pwd = null;

    try
    {
    // 以加密模式初始化密鑰
    cipher.init(Cipher.ENCRYPT_MODE,theKey,IvParameters);

    // 加密前的密碼(舊)
    byte[] plainttext = password.getBytes();

    // 加密密碼
    encrypted_pwd = cipher.doFinal(plainttext);

    // 轉成字符串,得到加密后的密碼(新)
    encrypted_password = new String(encrypted_pwd);
    }
    catch(Exception ex)
    {
    // 記錄加密錯誤
    }
    return encrypted_pwd;
    }

    /**
    * 解密算法
    * @param password 加過密的密碼
    * @return 解密后的密碼
    */
    public String decrypt(byte[] password)
    {
    String decrypted_password = null;
    try
    {
    // 以解密模式初始化密鑰
    cipher.init(Cipher.DECRYPT_MODE,theKey,IvParameters);

    // 構造解密前的密碼
    byte[] decryptedPassword = password;

    // 解密密碼
    byte[] decrypted_pwd = cipher.doFinal(decryptedPassword);
    // 得到結果
    decrypted_password = new String(decrypted_pwd);
    }
    catch(Exception ex)
    {
    // 記錄解密錯誤
    }
    return decrypted_password;
    }
    }

    posted on 2007-03-28 13:17 黑馬_2046 閱讀(853) 評論(1)  編輯  收藏 所屬分類: 加密解密

    評論

    # re: DES算法簡單例程  回復  更多評論   

    這個寫的不錯
    2007-08-10 09:40 | dreamstone

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


    網站導航:
     
    主站蜘蛛池模板: 久久久久久av无码免费看大片| 亚洲av一本岛在线播放| 国产三级电影免费观看| 亚洲免费一级视频| 国产成人高清亚洲一区久久| 三年片在线观看免费观看高清电影| 亚洲视频在线观看地址| 19禁啪啪无遮挡免费网站| 免费h成人黄漫画嘿咻破解版| 亚洲色偷偷综合亚洲av78 | 日韩在线免费视频| 亚洲国产电影在线观看| 免费精品人在线二线三线区别| 国产亚洲中文日本不卡二区 | 在线美女免费观看网站h| 在线播放免费播放av片| 亚洲免费网站观看视频| 免费国产怡红院在线观看| 日日摸夜夜添夜夜免费视频| 亚洲偷自拍拍综合网| 无人在线观看免费高清| 亚洲avav天堂av在线网爱情| 国产小视频在线免费| 亚洲精品视频专区| 日韩毛片免费无码无毒视频观看| 精品国产亚洲第一区二区三区| 亚洲一区二区三区免费在线观看| 亚洲videosbestsex日本| 日本一道一区二区免费看| 亚洲国产精品专区| 日本免费人成黄页网观看视频| 极品美女一级毛片免费| 亚洲AV无码国产精品色午友在线 | 中国一级特黄的片子免费 | 免费萌白酱国产一区二区| 久久免费香蕉视频| 亚洲国产成人久久99精品| 免费jjzz在线播放国产| 国产精品偷伦视频观看免费 | 中文字幕手机在线免费看电影| 亚洲综合激情视频|