<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 閱讀(848) 評論(1)  編輯  收藏 所屬分類: 加密解密

    評論

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

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

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


    網站導航:
     
    主站蜘蛛池模板: 亚洲AV日韩AV永久无码下载| 国产精品国产午夜免费福利看| 亚洲性色AV日韩在线观看| 亚洲伦乱亚洲h视频| 无限动漫网在线观看免费| 午夜精品一区二区三区免费视频| 亚洲av最新在线观看网址| 亚洲第一网站免费视频| 久久久久亚洲AV无码专区首JN| 亚洲人成网站观看在线播放| 成人免费毛片视频| 成人一a毛片免费视频| 91成人免费在线视频| 日韩免费一区二区三区在线 | 69成人免费视频| 无人在线直播免费观看| 91成人免费观看| 亚洲视频免费在线播放| 国产91免费视频| 在线视频免费观看高清| 在线观看无码AV网站永久免费| 97视频免费观看2区| 毛片a级毛片免费播放100| 国产美女无遮挡免费网站| 免费看无码自慰一区二区| 日韩激情淫片免费看| 亚洲区不卡顿区在线观看| 亚洲AV永久无码精品一百度影院| 亚洲欧洲日韩不卡| 在线aⅴ亚洲中文字幕| 又硬又粗又长又爽免费看 | 久久精品一区二区免费看| 国产精品免费无遮挡无码永久视频 | 又黄又爽又成人免费视频| 性感美女视频免费网站午夜| 亚洲第一区精品观看| 亚洲成人一级电影| www免费黄色网| 成人免费a级毛片| 亚洲AV无码久久精品色欲| 日本亚洲欧美色视频在线播放|