我需要在C#中加密和解密字符串。 我设法为从Java服务收到的字符串编写正确的解码器 - 3DES,DESede / ECB / NoPadding。
现在,我有一段时间相应地编码一个字符串。 下面是解密器(这是完美的,不需要任何更改)。
还附加了加密器,加密器应加密将使用附加的解密器解密的字符串。
解密器:
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);
}
加密(需要更改):
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);
}
答案 0 :(得分:2)
您需要移动
ICryptoTransform transformation = tdes.CreateDecryptor();
下面的行设置参数,因为CreateDecryptor
使用的参数(如Key
!)正好在TripleDESCryptoServiceProvider
上设置。但是在您的原始代码中,您创建了解密器,并且只有在设置了解密参数之后才会被使用(并且解密器会使用随机密钥)。用以下内容替换相关行:
var tdes = new TripleDESCryptoServiceProvider();
tdes.Key = keyBytes;
tdes.Mode = CipherMode.ECB;
tdes.Padding = PaddingMode.None;
ICryptoTransform transformation = tdes.CreateDecryptor();
它会起作用。
但请注意,您的代码是1)不必要的复杂,2)completely insecure。