- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要处理一大串短字符串(主要是俄语,但任何其他语言都是可能的,包括猫在键盘上行走的随机垃圾)。
其中一些字符串将在 UTF-8 中编码两次。
我需要可靠地检测给定的字符串是否被双重编码,并修复它。我应该在不使用任何外部库的情况下执行此操作,只需检查字节即可。检测应尽可能快。
问题是:如何检测给定的字符串以 UTF-8 编码两次?
更新:
原始字符串采用 UTF-8 格式。这是执行第二次编码的 AS3 代码(不幸的是我无法控制客户端代码,所以我无法解决这个问题):
private function toUTF8(s : String) : String {
var byteArray : ByteArray = new ByteArray();
byteArray.writeUTFBytes(s);
byteArray.position = 0;
var res : String = "";
while(byteArray.bytesAvailable){
res += String.fromCharCode(byteArray.readUnsignedByte());
}
return res;
}
myString = toUTF8(("" + myString).toLowerCase().substr(0, 64));
toLowerCase()
称呼。也许这可能有帮助?
最佳答案
原则上你不能,特别是允许猫垃圾。
您没有说明数据在进行一次或两次 UTF-8 编码之前的原始字符编码是什么。我将假设 CP1251,(或者至少 CP1251 是其中一种可能性),因为这是一个非常棘手的案例。
取一个非 ASCII 字符。 UTF-8 编码它。你得到一些字节,所有这些字节都是 CP1251 中的有效字符,除非其中一个恰好是 0x98,这是 CP1251 中唯一的漏洞。
因此,如果您将这些字节从 CP1251 转换为 UTF-8,结果与您正确使用 UTF-8 编码由这些俄语字符组成的 CP1251 字符串完全相同。无法判断结果是错误地对一个字符进行了双重编码,还是对 2 个字符进行了正确的单一编码。
如果您对原始数据有一定的控制权,则可以在其开头放置一个 BOM。然后,当它返回给您时,检查初始字节以查看您是否有 UTF-8 BOM,或者是否对 BOM 进行了错误的双重编码。但我想你可能对原文没有那种控制权。
在实践中你可以猜到 - UTF-8 解码它然后:
(a) 查看字符频率、字符对频率、不可打印字符的数量。这可能允许您暂时将其声明为无意义,因此可能会进行双重编码。如果有足够多的不可打印字符,它可能会非常荒谬,以至于您甚至无法通过敲击键盘来实际输入它,除非您的 ALT 键被卡住了。
(b) 尝试第二次解码。也就是说,从您通过解码 UTF-8 数据获得的 Unicode 代码点开始,首先将其编码为 CP1251(或其他),然后从 UTF-8 解码结果。如果任一步骤失败(由于字节序列无效),那么它肯定不是双重编码的,至少没有使用 CP1251 作为错误解释。
如果您有一些可能是 UTF-8 或 CP1251 的字节,而您不知道是哪个,这或多或少就是您所做的。
对于与双重编码数据无法区分的单编码猫垃圾,您会得到一些误报,对于双重编码的数据,可能会有极少的误报,但在第一次被 Fluke 编码后仍然看起来像俄语。
如果你的原始编码比 CP1251 有更多的漏洞,那么你的假阴性就会更少。
字符编码很难。
关于language-agnostic - 检测字符串是否以 UTF-8 进行双重编码,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5032448/
我对自定义 CSS 或在将图像作为 Logo 上传到页面时使用编码 block 有疑问。我正在为我的网站使用 squarespace,我需要帮助编码我的 Logo 以使其适合每个页面。一个选项是使用自
如 encoding/json 包文档中所述, Marshal traverses the value v recursively. If an encountered value implement
我必须做一些相当于Java中的iconv -f utf8 -t sjisMS $INPUT_FILE的事情。该命令在 Unix 中 我在java中没有找到任何带有sjisMS的编码。 Java中有Sh
从 PHP 5.3 迁移到 PHP 5.6 后,我遇到了编码问题。我的 MySQL 数据库是 latin1,我的 PHP 文件是 windows-1251。现在一切都显示为“ñëåäíèòå àäðå
我有一个 RScript文件(我们称之为 main.r ),它引用了另一个文件,使用以下代码: source("functions.R") 但是,当我运行 RScript 文件时,它提示以下错误:
我无法设法从 WSDL 创建 RPC/编码风格的代码 - 有谁知道哪个框架可以做到这一点? 带有 adb 和 xmlbeans 映射的 Axis2 无法正常工作(无法处理响应中的肥皂编码)直接使用 X
安装了最新版本的Node.Js()和npm包**(1.2.10)**当我运行 Express 命令来生成项目时,它向我抛出以下错误 buffer.js:240 switch (encoding &
JavaScript中有JSON编码/解码base64编码/解码函数吗? 最佳答案 是的,btoa() 和 atob() 在某些浏览器中可以工作: var enc = btoa("this is so
>>> unicode('восстановление информации', 'utf-16') Traceback (most recent call last): File "", line
我当然熟悉 java.net.URLEncoder 和 java.net.URLDecoder 类。但是,我只需要 HTML 样式的编码。 (我不想将 ' ' 替换为 '+' 等)。我不知道任何只做
有一个非常简单的 SSIS 包: OLE DB Source 通过 View 获取数据(数据库表 nvarchar 或 nchar 中的所有字符串列)。 派生列,用于格式化现有日期并将其添加到数据集(
我正在使用一个在 Node 中进行base64编码的软件,如下所示: const enc = new Buffer('test', 'base64') console.log(enc) 显示: 我正
前言 下文介绍的自定义协议仅作为学习示例,纯粹是玩具项目,没有实际可用性。无需过度关注和讨论其合理性 进行通信的双方是谁? 常见的模型 客户端-服务器,例如HTTP协议,浏览器<=>
我试图将带有日语字符的数据插入到 oracle 数据库中。事情是保存在数据库中的是一堆倒置的问号。我该如何解决这个问题 最佳答案 见 http://www.errcode.net/blogs/?p=6
当我在 java 中解压 zip 文件时,我发现文件名中出现了带有重音字符的奇怪行为。 西索: Add File user : L'equipe Technique -- Folder : spec
在网上冲浪我找到了 ExtJS 的 Ext.Gantt 插件,该扩展有一个特殊的编码。任何人都知道如何编码那样或其他复杂的形式。 Encoded Gantt Chart 最佳答案 它似乎被 Dean
我正在用C语言做一个编码任务,我进展顺利,直到读取符号并根据表格分配相应的代码的部分。我必须连接几个代码,直到它们的长度达到 32 位,为此我必须将它们写入一个文件中。这种写入文件的方法给我带来了很多
我有一个外部链接的 javascript 文件。在那个 javascript 里面,我有这个功能: function getMonthNumber(monthName){ monthName = mo
使用mechanize,我检索到一个网页的源页面,其中包含一些非ASCII字符,比如汉字。 代码如下: #using python2.6 from mechanize import Browser b
我有一个包含字母 ø 的文件。当我用这段代码 File.ReadLines(filePath) 读取它时,我得到了一个问号而不是它。 当我像这样添加编码时 File.ReadLines(filePat
我是一名优秀的程序员,十分优秀!