作者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