作者james0229 (james0229)
看板PHP
标题[请益] php生成xml 中文字无法显示问题
时间Thu Feb 16 12:25:16 2012
各位大家好
想请问各位,目前问题是想取得mssql内的资料,生成xml在网页上,
但是只要是资料表栏位资料输入为中文,生成xml就会出现错误,
错误讯息为b>Warning</b>: DOMElement::setAttribute() [<a
href='domelement.setattribute'>domelement.setattribute<...
附上原码:
<?php
ob_start();
header('Content-Type: text/xml');
$dom = new DOMDocument('1.0');
$dom->encoding = 'UTF-8';
$conn = mssql_connect("localhost", "sa", "12345");
mssql_select_db("DaShang", $conn);
$SQL="SELECT * FROM test"; //资料库存在,建立SQL命令字串
$datalist=mssql_query($SQL);//将回传结果存放於变数中
$root = $dom->createElement('root'); $dom->appendChild($root);// 建立母节点
$root
while ($fielddatas=mssql_fetch_array($datalist)) //将资料录转换为栏位阵列集合
{
$child1 = $dom->createElement('item'); $root->appendChild($child1);
//输出栏位资料
$child1->setAttribute('name', $fielddatas["name"]); // 设定属性
$child1->setAttribute('phone', $fielddatas["phone"]);
$child1->setAttribute('qnum', $fielddatas["qnum"]); // 设定属性
//$child1->setAttribute('question', $fielddatas["question"]);
}
$xmlStr = $dom->saveXML(); echo $xmlStr;
?>
其中这行//$child1->setAttribute('question', $fielddatas["question"]);
只要杠掉就可以完整生成xml,
<?xml version="1.0" encoding="UTF-8" ?>
- <root>
<item name="jack" phone="0933" qnum="2" />
<item name="jame/s" phone="0912" qnum="2" />
<item name="mary" phone="0920" qnum="3" />
</root>
想请教各位//$child1->setAttribute('question', $fielddatas["question"]);
这行是否要改用别的写法去存取?或是有其他地方没注意到的编码要转换的问题?
再拜托各位了~感谢!!!!!!
--
※ 发信站: 批踢踢实业坊(ptt.cc)
◆ From: 114.44.3.165
1F:→ kilfu0701:档案是用UTF8存的吗? 02/16 13:48
2F:→ james0229:查过SQL2008是预设为Unicode,但就是抓不到中文字。 02/16 13:59
3F:推 kerash:单纯印出不要用 xml 格式的话所有字都印的出来吗 02/16 15:11
4F:→ kerash:另外把 header 加上 charset='utf-8' 呢? 02/16 15:14
5F:→ james0229:k大,单纯印出没问题,header也有加了,一样错误。 02/16 16:11
6F:→ hSATAC:试试看 htmlentities($str, EN_XML1, 'UTF-8'); 02/16 16:23
7F:→ james0229:一样是错误讯息,还有其他方法吗?? 02/16 16:52
8F:推 kerash:connect 时加入以下 query 02/16 17:09
9F:→ kerash:mysql_query("set character_set_client=utf8"); 02/16 17:09
10F:→ kerash:mysql_query("set character_set_results=utf8"); 02/16 17:09
11F:→ kerash:mysql_query("set names utf8"); 02/16 17:09
12F:→ kerash:我刚刚自己测试抓 mysql 是出现问号,加以上几行解决 02/16 17:10
13F:→ james0229:mysql可以成功,但mssql还是无法,请问语法是相同吗? 02/16 17:22
14F:推 kerash:我header有加charset,dom编码是用 new DD('1.0','utf-8'); 02/16 17:33
15F:推 kerash:另外有可能你的 sql server 用的 unicode 不是 utf-8 ? 02/16 17:36
16F:→ buganini:换别的extension用,5.3之後就没有mssql extension了 02/17 10:15
17F:→ buganini:然後mssql extension印象中是只能用ANSI codepage(big5) 02/17 10:15
18F:→ buganini:改用freetds之类的吧 02/17 10:15
19F:→ buganini:或是用odbc,这样如果要换到unix平台也不用改程式码 02/17 10:17
20F:→ buganini:如果是以经写好的原本mssql的code的话,就直接用freetds 02/17 10:21
21F:→ buganini:freetds.conf里面data source段加client charset = UTF-8 02/17 10:22
22F:→ buganini:就可以了 02/17 10:22
23F:→ buganini:google一下范例很多;client charset放global也可 02/17 10:24
24F:→ james0229:後来用ADODB解决~感谢各位大哥~有空会将程式码补上 03/10 14:16