从加密数据中删除 ASCII 或 Unicode 字符

Remove ASCII or Unicode characters from encrypted data

我正在尝试使用 C# 获取存储在 MySQL 数据库中的加密代码。有时代码没问题,但有时我会在解密代码的末尾得到一些 ASCII 和 Unicode 字符。

我知道,由于 encryption/decryption 过程,您会得到一些额外的字符;问题是那些字符不一致(不像我总是在最后得到一堆 \0)。

codeA[=10=][=10=][=10=][=10=][=10=][=10=][=10=][=10=][=10=]
codeB\u0010\u0010\u0010\u0010\u0010\u0010\u0010\u0010\u0010
codeC\b\b\b\b\b\b\b\b\b
codeD\u0003\u0003\u0003\u0003\u0003\u0003\u0003\u0003\u0003

我得到了不同的结尾字符,老实说,很难为每个碰巧出现的字符添加一个 "Replace" 方法。

有没有办法删除最后的 "special" 个字符?或许我只是 storing/reading 代码有误?

我为PHP(网页utf-8,代码的编写者)和C#(console app,代码的reader)编写过程

PHP

// Get $code from html form in utf-8

$code = $_POST['code'];
$encrypted_code = base64_encode(openssl_encrypt($code, 'aes-256-ecb', 'keykeykeykeykeykeykeykey', OPENSSL_RAW_DATA)));

// Store $encrypted_code into database

C#

// Read encrypted_code from database using MySqlConnection

Aes aes = Aes.Create();
aes.Key = Encoding.UTF8.GetBytes("keykeykeykeykeykeykeykey");
aes.Mode = CipherMode.ECB;
aes.Padding = PaddingMode.None;
aes.IV = new byte[] { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 };
ICryptoTransform decryptor = aes.CreateDecryptor(aes.Key, aes.IV);
string code = null;
using (aes)
{
            byte[] encrypted_code = Convert.FromBase64String(encrypted_code);
            using (var encrypted_stream = new MemoryStream(encrypted_code))
            using (var decrypter_stream = new CryptoStream(encrypted_stream, decryptor, CryptoStreamMode.Read))
            using (var decrypted_stream = new StreamReader(decrypter_stream))
            code = decrypted_stream.ReadLine().
                        Replace("[=12=]", string.Empty).
                        Replace("\b", string.Empty).
                        Replace("\v", string.Empty).
                        Replace("\t", string.Empty).
                        Replace("\u0010", string.Empty).
                        Replace("\u0003", string.Empty).
                        Replace("\u0006", string.Empty);
}

//Use code for whatever

默认情况下,您选择的 PHP 加密方法会添加填充,returns 数据结果类似于 "CodeA[=23=][=23=][=23=][=23=][=23=][=23=][=23=][=23=][=23=]"。为了获得不带填充返回的解密数据,只需将 C# 代码中的 PaddingMode 更改为:

aes.Padding = PaddingMode.PKCS7;


顺便说一句: 这段代码: $encrypted_code = openssl_encrypt($code, 'aes-256-ecb', 'keykeykeykeykeykeykeykey');

产生与此代码相同的结果: $encrypted_code = base64_encode(openssl_encrypt($code, 'aes-256-ecb', 'keykeykeykeykeykeykeykey', OPENSSL_RAW_DATA));