首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >C# 3 3DES Encryption+Decryption (ECB+No padding+no IV)

C# 3 3DES Encryption+Decryption (ECB+No padding+no IV)
EN

Stack Overflow用户
提问于 2015-09-03 20:56:25
回答 1查看 4.7K关注 0票数 1

我需要在C#中加密和解密一个字符串。我已经成功地为从Java服务接收到的字符串编写了正确的解码器-3 3DES,DESede/ECB/NoPadding。

现在,我有一段时间相应地编码一个字符串。下面是解密器(这是完美的,不需要任何更改)。

还附加了加密器,该加密器应该加密将被附加的解密器解密的字符串。

解密器:

代码语言:javascript
复制
public static string Decryptor240815B(string Message) /* Working */
{
    string cipher = Message.Replace(" ", "+");
    byte[] keyBytes;
    string cipherString = FromHexString(cipher);
    byte[] cipherBytes = Convert.FromBase64String(cipherString);

    keyBytes = UTF8Encoding.UTF8.GetBytes(seed);

    var tdes = new TripleDESCryptoServiceProvider();
    tdes.Key = keyBytes;
    tdes.Mode = CipherMode.ECB;
    tdes.Padding = PaddingMode.None;

    ICryptoTransform transformation = tdes.CreateDecryptor();
    byte[] decryptedBytes = transformation.TransformFinalBlock(cipherBytes, 0, cipherBytes.Length);
    tdes.Clear();

    string response = UTF8Encoding.UTF8.GetString(decryptedBytes);
    return response;
}

public static string FromHexString(string hexString)
{
    var bytes = new byte[hexString.Length / 2];
    for (var i = 0; i < bytes.Length; i++)
    {
        bytes[i] = Convert.ToByte(hexString.Substring(i * 2, 2), 16);
    }

    return Encoding.UTF8.GetString(bytes); 
}

加密器(需要更改):

代码语言:javascript
复制
public static string Encrypt030915(string message)
{
    byte[] keyBytes = UTF8Encoding.UTF8.GetBytes(seed);
    //string hexedMSG = StringToHexString(message);
    byte[] textBytes = UTF8Encoding.UTF8.GetBytes(message);

    TripleDESCryptoServiceProvider tdes = new TripleDESCryptoServiceProvider();
    ICryptoTransform cTransform = tdes.CreateEncryptor();

    tdes.Key = keyBytes;
    tdes.Mode = CipherMode.ECB;
    tdes.Padding = PaddingMode.None;
    byte[] resultArray = cTransform.TransformFinalBlock(textBytes, 0, textBytes.Length);

    tdes.Clear();

    string base64 = Convert.ToBase64String(resultArray);
    string retVal = FromBase64ToHEX(base64);
    return retVal;
    //byte[] ba = Encoding.UTF8.GetBytes(base64);
//    return ToHexString(resultArray); 
    //return ByteArrayToString030915(ba); 

}

private static string FromBase64ToHEX(string base64)
{
    char[] c = new char[base64.Length * 2];
    byte b;
    for (int i = 0; i < base64.Length; ++i)
    {
        b = ((byte)(base64[i] >> 4));
        c[i * 2] = (char)(b > 9 ? b + 0x37 : b + 0x30);
        b = ((byte)(base64[i] & 0xF));
        c[i * 2 + 1] = (char)(b > 9 ? b + 0x37 : b + 0x30);
    }
    return new string(c);
}
EN

回答 1

Stack Overflow用户

发布于 2015-09-07 20:23:37

你需要移动

代码语言:javascript
复制
ICryptoTransform transformation = tdes.CreateDecryptor();

在设置参数的下面一行,因为CreateDecryptor使用参数(如Key!)因为他们现在被设定在TripleDESCryptoServiceProvider上。但是在原始代码中,只在设置了解密参数之后才创建解密器,这些参数根本不被使用(并且解密器可以使用随机密钥)。将有关项目改为:

代码语言:javascript
复制
var tdes = new TripleDESCryptoServiceProvider();
tdes.Key = keyBytes;
tdes.Mode = CipherMode.ECB;
tdes.Padding = PaddingMode.None;
ICryptoTransform transformation = tdes.CreateDecryptor();

它会成功的。

但是,请注意,您的代码不必要地复杂,2) 完全不安全

票数 4
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32385272

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档