【发布时间】:2020-06-02 01:13:36
【问题描述】:
我正在尝试使用 C# 获取存储在 MySQL 数据库中的加密代码。有时代码很好,但有时我会在解密代码的末尾得到一些 ASCII 和 Unicode 字符。
我了解,由于加密/解密过程,您会得到一些额外的字符;问题是这些字符不一致(不像我最后总是得到一堆 \0)。
codeA\0\0\0\0\0\0\0\0\0
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
我得到了不同的结尾字符,老实说,很难为每个出现的字符添加“替换”方法。
有没有办法在最后删除那些“特殊”字符?还是我只是存储/读取代码错误?
我为 PHP(网页 utf-8,代码编写者)和 C#(控制台应用,代码阅读者)编写流程
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("\0", 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
【问题讨论】:
-
0x10 是数据链接转义,0x03 是文本结束。您可以检查源是否在开头包含这些特殊字符。
标签: c# encryption unicode ascii