- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我知道不同字符集之间的字符编码存在一个由来已久的问题,但我一直停留在与 Window 的“大引号”相关的问题上。
我们有一个客户喜欢将数据复制并粘贴到文本字段中,然后将其发布到我们的应用程序中。该数据通常会包含弯引号。我曾经使用以下方法将它们转换为正常的对应物:
function convert_smart_quotes($string) {
$badwordchars=array("\xe2\x80\x98", "\xe2\x80\x99", "\xe2\x80\x9c", "\xe2\x80\x9d", "\xe2\x80\x93", "\xe2\x80\x94", "\xe2\x80\xa6");
$fixedwordchars=array("'", "'", '"', '"', '-', '--', '...');
return str_replace($badwordchars,$fixedwordchars,$string);
}
几个月来效果很好。然后经过一些更改(我们切换服务器、更新系统、升级 PHP 等)后,我们了解到它不再起作用了。所以,我看了一下,发现“弯引号”都变成了不同的字符。在这种情况下,它们将变成以下内容:
“=¡È
”=¡É
' = ¡È
’ = ¡Ç
当保存在数据库中时,这些字符会显示为该死的“黑色菱形问号符号”。 mySQL 数据库位于 latin1_swedish_ci 中,接收消息的应用程序也是如此。因此,尽管我知道 utf-8 更好,但它必须保留在 latin1_swedish_ci 或 ISO-8859-1 中,否则我们将不得不重建所有内容……这是不可能的。
我的网页和表单都以 utf-8 格式发布。如果我将其更改为 ISO-8859-1,引号就会变成问号。
我曾尝试在字符串中搜索出现的“¡È”或“¡É”并将它们替换为普通引号,但我无法让它工作。我通过在上面的函数中添加以下内容来做到这一点:
$string = str_replace("xa1\xc8", '"', $string);
$string = str_replace("xa1\xc9", '"', $string);
$string = str_replace("xa1\xc6", "'", $string);
$string = str_replace("xa1\xc7", "'", $string);
我已经被困在这个问题上几个小时了,一直无法在线找到任何真正的帮助。可以想象,用谷歌搜索“¡É”不会带来非常具体的响应。
感谢任何指导!
最佳答案
您的问题是您正在接受来自用户的 UTF-8 输入,然后将其插入到您的数据库中,就好像它是 Latin1 (ISO-8859-1)。 (请注意,latin1_swedish_ci
不是编码,而是整理(对于 Latin1)。参见 this SO question on the difference。为了解决您的角色 em>encoding问题,排序不重要。)
与其手动识别重要的 UTF-8 序列并替换它们,不如使用可靠的方法将 UTF-8 字符串转换为 Latin1,例如 iconv
.
请注意,这是一个有损转换:某些 UTF-8 字符(例如大引号)在 Latin1 中不存在。您可以选择忽略这些字符(将它们替换为空字符串、? 或其他字符),或者您可以选择音译它们(将它们替换为相近的等值字符,例如 "
用于大引号...但是如果有人将 金
放入您的表单中,您会怎么做?
iconv
将尝试在可能的地方进行音译:
// convert from utf8 to latin1, approximating out of range characters
// by the closest latin1 alternative where possible (//TRANSLIT)
$latinString = iconv("UTF-8", "ISO-8859-1//TRANSLIT", $utf8String);
(您还可以将其配置为忽略所有超出范围的字符 — 有关更多信息,请参阅 iconv
's documentation。)
如果您不想添加新库,PHP 还附带了 utf_decode
功能:
$latinString = utf_decode($utf8String);
但是,PHP 在设计时并没有真正考虑到多种字符编码,因此我更愿意远离处理编码的(有时是错误的)标准库函数。
关于PHP Curly Quote 字符编码问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21716929/
我对自定义 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) 显示: 我正
我试图将带有日语字符的数据插入到 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
如何翻译下面的字符串 H.P. Dembinski, B. K\'{e}gl, I.C. Mari\c{s}, M. Roth, D. Veberi\v{c} 进入 H. P. Dembinski,
我是一名优秀的程序员,十分优秀!