- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我的页面中有一个表单供用户发表评论。
我目前正在使用这个字符集:
meta http-equiv="Content-Type" content="text/html;charset=ISO-8859-1"
但从 DB 重音检索评论显示不正确(Ex. è =>è)。
为了正确处理重音,我应该关注哪些参数?
已解决
将元标记更改为 charset='utf-8'
更改字符集 Mysql(ALTER TABLE comments CONVERT TO CHARACTER SET utf-8)
在插入记录和检索时都更改了连接字符集($conn->query('SET NAMES utf8'))
现在重音显示正确
谢谢
卢卡
最佳答案
当涉及到 LAMP 网络应用程序时,字符集可能很复杂且难以调试。在一个软件与另一个软件对话的每个阶段,都存在不正确的字符集转换或不正确的数据存储的范围。
您需要注意的地方是: - 在浏览器和网络服务器之间(您已经列出) - 在 PHP 和 MySQL 服务器之间
您列出的字符看起来像正常的欧洲字符,将包含在 ISO-8859-1 字符集中。
要检查的事项:
您没有说您是使用同一个网络应用程序还是使用其他客户端从数据库中读取数据。我建议您尝试使用相同的 Web 应用程序并使用相同的元字符集 header 来读取它(同样,检查浏览器是否真的设置了它)并查看浏览器中显示的内容。
要调试这些问题,您需要真正确定您使用的客户端/控制台是否也在进行任何转换,最安全的方法有时是将数据放入十六进制编辑器中,您可以确保没有其他任何东西正在搞乱任何翻译。
如果它看起来不像是浏览器端问题,请将以下命令的输出包含在您的数据库中:
从您的网络应用建立的连接运行(而不是从其他 MySQL 客户端):
SHOW VARIABLES LIKE 'character_set%';
SHOW VARIABLES LIKE 'collation%';
从任何 MySQL 客户端运行:
SHOW CREATE TABLE myTable;
(其中 myTable 是您要从中读取/写入数据的表)
关于PHP 字符集重音问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/5696378/
我正在寻找一种方法来支持不区分大小写 + 重音不区分搜索的良好性能。到目前为止,我们在使用 MSSql 服务器时没有遇到任何问题,在 Oracle 上我们必须使用 OracleText,而现在我们在
这个问题已经有答案了: Trouble with UTF-8 characters; what I see is not what I stored (5 个回答) 已关闭 5 年前。 我刚刚将一个我
我正在寻找一种在 Linux 中使用反引号 (`)/波形符 (~) 键和其他一些键创建键盘快捷键的方法。在理想情况下: 按下波形符没有任何作用 按下波形符的同时按另一个键会触发(可自定义的)快捷方式
我有一个由术语组成的数组,其中一些包含重音字符。我像这样做一个 preg grep $data= array('Napoléon','Café'); $result = preg_grep('~' .
我使用 TextBox 在 DataGridView 中进行过滤 image .这是完美的工作。表格的单元格包含 1250 个拉丁字符。我想搜索忽略单元格中单词的重音。例子。如果是文本框 "knjaz
我在 Vim 中遇到一个奇怪的映射问题。我使用的是 Azerty 键盘。 在我的 .vimrc 中,我有以下命令可以在段落之间快速移动。 nnoremap _ { vnoremap _ { nnore
我尝试读取一个utf8编码的vcf文件,结果是: { "name": "=4A=61=76=69=65=72=20=4C=75=6A=C3=A1=6E", "tel":
我的数据库中有两个表,info 和 comment,它们的结构如下: info (id(int(10)), name(varchar(80)), ...19 other columns.., phon
我使用 QtWebkit 制作了一个应用程序。在同一个 html 页面中,在 Windows 上使用重音符号(西类牙语)时可以正常工作,但在 Linux (Ubuntu) 上则不起作用。 我不明白为什
我有(例如)两个字符串: $a = "joao"; $b = "joão"; if ( strtoupper($a) == strtoupper($b)) { echo $b; } 我希望它是
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: invalid multibyte char (US-ASCII) with Rails and Ruby
我重写 URL 以包含用户生成的旅游博客的标题。 我这样做是为了 URL 的可读性和 SEO 目的。 http://www.example.com/gallery/280-Gorges_du_Tod
我最近安装了新的 Windows 10 build 14393,我想使用新的 linux 子系统。所以我决定学习 ncurses,但我找不到如何从 getch 中获取带有重音符的字符的 UTF-8 代
我是一名优秀的程序员,十分优秀!