3

我在 MySQL 字段中有一些法语文本,在 PHPMyAdmin 下正确显示:

mentionné

该字段被编码为utf32_unicode_ci。(它是一个varchar(500), utf32_unicode_ci)。

但是调用 PHP 脚本调用此参数并以 utf-8 编码的 html 输出会返回:

mentionn�

这是我的 php html 标头的摘录:

<html xmlns="http://www.w3.org/1999/xhtml" dir="ltr" lang="fr-FR">
<head profile="http://gmpg.org/xfn/11">
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8" />

我怎样才能解决这个问题?

4

1 回答 1

2

除了数据库编码,请务必检查以下内容:

  • 文件(js/php)的utf8编码(在超编辑下,F12:另存为UTF8-NOBOM)
  • utf8 html内容:<meta HTTP-EQUIV="content-type" CONTENT="text/html; charset=utf-8">
  • 您的数据库连接的utf8: SET character_set_connection = 'utf8'
  • 您的查询结果的 utf8 格式:SET character_set_results = 'utf8'
  • 您的数据库客户端的utf8:SET character_set_client = 'utf8'
  • 你的mysql表的utf8:ALTER TABLE table CONVERT TO CHARACTER SET utf8;
  • 您的数据库服务器的utf8:SET character_set_database = 'utf8'SET character_set_server = 'utf8'
  • 在某些情况下,当硬编码值需要编码时,必须在文件中强制使用 utf8。例如,您需要在文件顶部添加评论,使用charset=utf-8, 以便超级编辑或您喜欢的编辑器可以检测到它。

rgds。

ps:我不知道 utf32 但不知怎么的逻辑应该是一样的

于 2012-07-11T12:37:24.920 回答