XMLWriter(PHP)的编码问题

时间:2012-04-16 14:34:33

标签: php utf-8 xmlwriter

采用这个简单的PHP代码:

$xmlWriter = new XMLWriter();
$xmlWriter->openURI('php://output');
$xmlWriter->startDocument('1.0', 'utf-8');

$xmlWriter->writeElement('test', $data);

$xmlWriter->endDocument();
$xmlWriter->flush();

XMLWriter类有一个很好的功能:它会将您提供给它的任何数据转换为输出编码。例如,它会将$data转换为UTF-8,因为我在'utf-8'函数中传递了startDocument

问题在于,在我的情况下,$data的内容来自数据库,其输出格式为UTF-8,因此已经是UTF-8 。 XMLWriter 可能认为数据在ISO-8859-1中并再次转换为UTF-8,我得到奇怪的符号我应该在哪里获得重音。

目前我在数据库的每个字符串周围使用utf8_decode,这意味着我将从UTF-8转换为ISO-8859-1,然后XMLWriter将其转换回UTF-8。 / p>

这有效但不干净:

$xmlWriter->writeElement('test', utf8_decode($data));

有更清洁的解决方案吗?

编辑:显示完整的示例

$xmlWriter = new XMLWriter();
$xmlWriter->openURI('php://output');
$xmlWriter->startDocument('1.0', 'utf-8');
$xmlWriter->startElement('usersList');

$database = new PDO('mysql:host=localhost;dbname=xxxxx', 'xxxxx', 'xxxxx');
$database->exec('SET CHARACTER SET UTF8');
$database->exec('SET NAMES UTF8');
foreach ($database->query('SELECT name FROM usersList') as $user)
   $xmlWriter->writeElement('user', $user[0]);   // if the user's name is 'hervé' in the database, it will print 'hervé' instead

$xmlWriter->endElement();
$xmlWriter->endDocument();
$xmlWriter->flush();

1 个答案:

答案 0 :(得分:7)

我不确定你在哪里知道XMLWriter转换编码。它没有。您必须使用utf-8提供它。它可以输出不同的编码,但输入字符串必须是utf-8。

这里可能会发生以下两件事之一:

  1. 无论您使用什么来查看,您的输出文档都会将字符串解释为win-1252。如果您在浏览器中查看输出,则可能需要设置内容类型标题,如下所示:header('Content-Type: application/xml; charset=UTF-8');
  2. 您错误地将数据存储在数据库中,而“é”实际上是两个unicode字符“Ô。解决这个问题很困难。