繁体   English   中英

DES加密/解密中的C#编码

[英]C# encoding in DES encryption/decryption

我的main方法运行没有错误,但解密的消息不正确。 我几乎可以肯定我没有正确编码,但我无法确定问题。 任何帮助将不胜感激。

这是我的第一篇文章,所以如果我无意中违反了规则或没有遵守指南,请告诉我。

static void Main(string[] args)
{
    string unencryptedString = "cat";
    string encryptedString;
    string decryptedString;

    string password = "password";

    System.Console.WriteLine("Unencrypted String: " + unencryptedString);
    System.Console.WriteLine("Password: " + password);

    encryptedString = StandardEncryptor.Encrypt(unencryptedString, password);
    System.Console.WriteLine("Encrypted String: " + encryptedString);

    decryptedString = StandardEncryptor.Decrypt(encryptedString, password);
    System.Console.WriteLine("Decrypted String: " + decryptedString);

    System.Console.ReadLine();
}

public static string Encrypt(string message, string password)
{
    // Encode message and password
    byte[] messageBytes = ASCIIEncoding.ASCII.GetBytes(message);
    byte[] passwordBytes = ASCIIEncoding.ASCII.GetBytes(password);

    // Set encryption settings -- Use password for both key and init. vector
    DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
    ICryptoTransform transform = provider.CreateEncryptor(passwordBytes, passwordBytes);
    CryptoStreamMode mode = CryptoStreamMode.Write;

    // Set up streams and encrypt
    MemoryStream memStream = new MemoryStream();
    CryptoStream cryptoStream = new CryptoStream(memStream, transform, mode);
    cryptoStream.Write(messageBytes, 0, messageBytes.Length);
    cryptoStream.FlushFinalBlock();

    // Read the encrypted message from the memory stream
    byte[] encryptedMessageBytes = new byte[memStream.Length];
    memStream.Position = 0;
    memStream.Read(encryptedMessageBytes, 0, encryptedMessageBytes.Length);

    // Encode the encrypted message as base64 string
    string encryptedMessage = Convert.ToBase64String(encryptedMessageBytes);

    return encryptedMessage; 
}

public static string Decrypt(string encryptedMessage, string password)
{
    // Convert encrypted message and password to bytes
    byte[] encryptedMessageBytes = Convert.FromBase64String(encryptedMessage);
    byte[] passwordBytes = ASCIIEncoding.ASCII.GetBytes(password);

    // Set encryption settings -- Use password for both key and init. vector
    DESCryptoServiceProvider provider = new DESCryptoServiceProvider();
    ICryptoTransform transform = provider.CreateDecryptor(passwordBytes, passwordBytes);
    CryptoStreamMode mode = CryptoStreamMode.Write;

    // Set up streams and decrypt
    MemoryStream memStream = new MemoryStream();
    CryptoStream cryptoStream = new CryptoStream(memStream, transform, mode);
    cryptoStream.Write(encryptedMessageBytes, 0, encryptedMessageBytes.Length);
    cryptoStream.FlushFinalBlock();

    // Read decrypted message from memory stream
    byte[] decryptedMessageBytes = new byte[memStream.Length];
    memStream.Position = 0;
    memStream.Read(decryptedMessageBytes, 0, decryptedMessageBytes.Length);

    // Encode deencrypted binary data to base64 string
    string message = Convert.ToBase64String(decryptedMessageBytes);

    return message;
}

问题是倒数第二行吗?

string message = Convert.ToBase64String(decryptedMessageBytes);

我可能在这里偏离轨道,但我认为你不打算将字符串字节转换回base64。 你只需要将字节转换回字符串吗?

string message = ASCIIEncoding.ASCII.FromBytes(decryptedMessageBytes);

我使用这个来解决问题

//Encode deencrypted binary data to base64 string
string message = ASCIIEncoding.ASCII.GetString(decryptedMessageBytes);

看起来问题出现在Decrypt中:

// Encode deencrypted binary data to base64 string
string message = Convert.ToBase64String(decryptedMessageBytes);

我认为你不想对解密数据这样做。 解密的字节已经是ASCII。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM