C# 在c语言中,有时以64个无效字符为基数#

C# 在c语言中,有时以64个无效字符为基数#,c#,asp.net,encryption,cryptography,C#,Asp.net,Encryption,Cryptography,我正在c#asp.net中开发一个处理保留信息的应用程序 为此,我做了一些研究,并在本教程中从c#中分别提出了以下两个加密和解密函数: 我已经证实,有些情况下解密出错,例如 加密(“a808XXX”)不工作 加密(“A808XXX”)工作 加密(“a631XXX”)工作 加密(“A631XXX”)不工作 错误是: base64无效字符 我已尝试应用替换语法,但未成功: Request.QueryString["m"].ToString().Replace(" ", "+") 下面是我的代码,

我正在c#asp.net中开发一个处理保留信息的应用程序

为此,我做了一些研究,并在本教程中从c#中分别提出了以下两个加密和解密函数:

我已经证实,有些情况下解密出错,例如

加密(“a808XXX”)不工作

加密(“A808XXX”)工作

加密(“a631XXX”)工作

加密(“A631XXX”)不工作

错误是:

base64无效字符

我已尝试应用替换语法,但未成功:

Request.QueryString["m"].ToString().Replace(" ", "+")
下面是我的代码,如何解决这个问题

请帮帮我,先谢谢你

public string Encrypt(string clearText)
{
    string EncryptionKey = "MAKV2SPBNI99212";
    byte[] clearBytes = Encoding.Unicode.GetBytes(clearText);
    using (Aes encryptor = Aes.Create())
    {
        Rfc2898DeriveBytes pdb = new Rfc2898DeriveBytes(EncryptionKey, new byte[] { 0x49, 0x76, 0x61, 0x6e, 0x20, 0x4d, 0x65, 0x64, 0x76, 0x65, 0x64, 0x65, 0x76 });
        encryptor.Key = pdb.GetBytes(32);
        encryptor.IV = pdb.GetBytes(16);
        using (MemoryStream ms = new MemoryStream())
        {
            using (CryptoStream cs = new CryptoStream(ms, encryptor.CreateEncryptor(), CryptoStreamMode.Write))
            {
                cs.Write(clearBytes, 0, clearBytes.Length);
                cs.Close();
            }
            clearText = Convert.ToBase64String(ms.ToArray());
        }
    }
    return clearText;
}



private string Decrypt(string cipherText)
{
    string EncryptionKey = "MAKV2SPBNI99212";
    byte[] cipherBytes = Convert.FromBase64String(cipherText);
    using (Aes encryptor = Aes.Create())
    {
        Rfc2898DeriveBytes pdb = new Rfc2898DeriveBytes(EncryptionKey, new byte[] { 0x49, 0x76, 0x61, 0x6e, 0x20, 0x4d, 0x65, 0x64, 0x76, 0x65, 0x64, 0x65, 0x76 });
        encryptor.Key = pdb.GetBytes(32);
        encryptor.IV = pdb.GetBytes(16);
        using (MemoryStream ms = new MemoryStream())
        {
            using (CryptoStream cs = new CryptoStream(ms, encryptor.CreateDecryptor(), CryptoStreamMode.Write))
            {
                cs.Write(cipherBytes, 0, cipherBytes.Length);
                cs.Close();
            }
            cipherText = Encoding.Unicode.GetString(ms.ToArray());
        }
    }
    return cipherText;
}
错误消息:“base64无效字符”已清除

调试:找到错误,在错误发生的地方修复错误。不要只是开始尝试

加密后打印Base64字符串,解密前再次打印

比较以查找差异/损坏

验证两个Base64字符串仅包含有效字符“A-Za-z/+”以及可能包含一个或两个尾随“=”字符


如果Base64字符串是查询字符串的一部分,则可能需要对其进行URL编码。

您必须至少替换字符+和/

试试像这样的东西

.Replace("+", "-").Replace("/", "_");

显然,在解密之前,您必须执行相反的操作。

Base64字符串可能包含
/+=
字符,如果在查询字符串中发送不正确,则可能会导致问题,您是这样做的吗?如果是,请参见,如果不是,您需要显示从调试器捕获的
明文值以及发送到
Decrypt()
的相应字符串,但不确定这是否会纠正您的问题,但您应该在cs.Write call in Encrypt之后添加cs.FlushFinalBlock()。@Kevin感谢您的回复,但我不理解你的建议,它确保在关闭流之前将最终加密的块写入流。你应该注意Alex关于url中base64字符的完整评论(querystring等),因此建议“base64urlencode”-re:调试
m
的值,以便查看实际使用的内容。另外,在.Net中有一个实现,可以使用适合您的工具。嗯。。。