gpt4 book ai didi

c++ - 将亚洲和其他字符放入 Visual Studio 源代码中

转载 作者:行者123 更新时间:2023-11-28 06:30:32 25 4
gpt4 key购买 nike

我加密了很多导致这个的文本:

const char* encrypted[] = {
"ꖟ럵꼹ᐦෑ䵖","ꗹモ拧ᔞ诞凲ḏ","᜷瞗긚⧿숯塚","輶䖙挿斃ぁ忋","掂䉧딻䠕᭖嬽핹ճ","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","ㄿ爛泰먅轭➊㻎⌧","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋",
"욊蚘坸ꭤ䱤㇔鸽","욊蚘坸ꭤ䱤㇔鸽","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","䀴♃�ハ狥䖢","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋","輶䖙挿斃ぁ忋"
}

问题是,Visual Studio 2013 给出了关于它的各种错误。我已经将编码更改为没有 BOM 的 UTF-8,否则如果我尝试编译它,编译器会立即崩溃。它给出了各种文本错误,例如:'0x80':标识符中不允许使用此字符。我尝试在文本前添加 u8,使其成为 UTF-8 例如:u8"ꖟ럵꼹ᐦෑ䵖" 只是给出错误:未找到 u8 标识符

有没有办法将加密文本成功加载到您的源代码中?

最佳答案

问题在于 AES 生成的输出与随机输出无法区分。基本上这意味着任何字节都可以包含任何值。然而,并非所有字节值都是有效的字符编码。基本上,您是在要求系统将二进制转换回字符,而二进制从一开始就不是由字符构造的。

发生的是无法识别的字节编码被静默删除。 不可打印 字符可能会发生同样的事情,例如 Unicode 代码点 0x20 (32) 以下的字符。所以最后解码成字符串再编码回字节会导致数据丢失。这种数据丢失当然也是随机发生的;对于更短的密文,你可能很幸运,根本没有数据丢失。

现在如果您根本需要一个字符串,那么答案是使用一种编码,将二进制编码为字符串并再次无损地编码。对于相对高效的编码(每 3 个字节 4 个字符),大多数开发人员选择 base64。如果您只想显示一些较小的值,那么十六进制将具有更容易被人眼阅读的优势(每个字节 2 个字符)。对于代码中的密文、 key 和 IV 的测试代码,我个人总是更喜欢十六进制,因为它很容易查看/计算大小。

在 C/C++ 等语言中,您还可以使用 \xXX 将所有内容编码为 unsigned char*。我会警告不要这样的做法,因为它会诱使您使用字符串函数,例如 strlen。如果使用空终止字符串,这当然是一个问题。尝试始终明确区分字符和字节,即使语言没有区分。更好的选择是使用 char[] (和 sizeof 而不是 strlen)。

关于c++ - 将亚洲和其他字符放入 Visual Studio 源代码中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27668842/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com