日期:2014-05-20  浏览次数:20980 次

求大神把java代码DES加密函数,翻译成C#版的
网上搜索过,但加密出来的结果 跟java的死活不一样,头都晕了,哪位大神可以翻译成C#版的,万分感谢啊!
java代码如下:
 
Java code
public static String DESDecrypt(String data, String key, String encoding)
{
    String edata = data;
    try
    {
        MessageDigest digest = MessageDigest.getInstance("MD5");

        digest.update(key.getBytes(encoding));
        DESedeKeySpec dks = new DESedeKeySpec(convert16To24(digest.digest()));
        SecretKeyFactory keyFactory = SecretKeyFactory.getInstance("DESede");
        SecretKey securekey = keyFactory.generateSecret(dks);
        Cipher cipher = Cipher.getInstance("DESede/ECB/PKCS5Padding");
        cipher.init(Cipher.DECRYPT_MODE , securekey, new SecureRandom());
        if (!data.endsWith( "=" ))
        {
            data = URLDecoder.decode(data, encoding);
        }
        edata = new String(cipher.doFinal(BASE64Decrypt(data)), encoding);
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }
    return edata;
}


/**
* BASE64 解密
*
* @param key
* @return
* @throws Exception
*/
public static byte [] BASE64Decrypt(String data)
{
    byte [] edata = null ;
    try
    {
        edata = ( new BASE64Decoder()).decodeBuffer(data);
    }
    catch (Exception e)
    {
        e.printStackTrace();
    }
    return edata;
}


/**
* 把 16 位凑成 24 位数组。
*
* @param okey
* @return
*/
private static  byte [] convert16To24(byte [] okey)
{
    byte [] dkey = new byte [24];
    for (int i = 0; i < dkey. length ; i++)
    {
        dkey[i] = okey[i % 16];
    }
    return dkey;
}



------解决方案--------------------
http://www.cnblogs.com/weekzero/archive/2007/12/05/983143.html
------解决方案--------------------
c/c++也可以啊
------解决方案--------------------
路过...
------解决方案--------------------
引用一楼
des是常用的对称加密解密方法,下面是C#下的核心代码
/// <summary>
/// 进行DES加密。
/// </summary>
/// <param name="pToEncrypt">要加密的字符串。</param>
/// <param name="sKey">密钥,且必须为8位。</param>
/// <returns>以Base64格式返回的加密字符串。</returns>
public string Encrypt(string pToEncrypt, string sKey)
{
using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
{
byte[] inputByteArray = Encoding.UTF8.GetBytes(pToEncrypt);
des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);
des.IV = ASCIIEncoding.ASCII.GetBytes(sKey);
System.IO.MemoryStream ms = new System.IO.MemoryStream();
using (CryptoStream cs = new CryptoStream(ms, des.CreateEncryptor(), CryptoStreamMode.Write))
{
cs.Write(inputByteArray, 0, inputByteArray.Length);
cs.FlushFinalBlock();
cs.Close();
}
string str = Convert.ToBase64String(ms.ToArray());
ms.Close();
return str;
}
}

/// <summary>
/// 进行DES解密。
/// </summary>
/// <param name="pToDecrypt">要解密的以Base64</param>
/// <param name="sKey">密钥,且必须为8位。</param>
/// <returns>已解密的字符串。</returns>
public string Decrypt(string pToDecrypt, string sKey)
{
byte[] inputByteArray = Convert.FromBase64String(pToDecrypt);
using (DESCryptoServiceProvider des = new DESCryptoServiceProvider())
{
des.Key = ASCIIEncoding.ASCII.GetBytes(sKey);