伺服器上的 XML
XML 檔是類似 HTML 檔的純文本檔。
XML 能夠通過標準的 Web 伺服器輕鬆地存儲和生成。
在伺服器上存儲 XML 檔
XML 檔在 Internet 伺服器上進行存儲的方式與 HTML 檔完全相同。
啟動 Windows 記事本,並寫入以下行:
<?xml version="1.0" encoding="ISO-8859-1"?>
<note>
<from>Jani</from>
<to>Tove</to>
<message>Remember me this weekend</message>
</note>
<note>
<from>Jani</from>
<to>Tove</to>
<message>Remember me this weekend</message>
</note>
然後用適當的檔案名,比如 "note.xml",在 Web 伺服器上保存這個檔。
通過 ASP 生成 XML
XML 可在不安裝任何 XML 軟體的情況下在伺服器端生成。
如需從伺服器生成 XML 回應 - 只需簡單地編寫以下代碼並在 Web 伺服器上把它保存為一個 ASP 檔:
<%
response.ContentType="text/xml"
response.Write("<?xml version='1.0' encoding='ISO-8859-1'?>")
response.Write("<note>")
response.Write("<from>Jani</from>")
response.Write("<to>Tove</to>")
response.Write("<message>Remember me this weekend</message>")
response.Write("</note>")
%>
response.ContentType="text/xml"
response.Write("<?xml version='1.0' encoding='ISO-8859-1'?>")
response.Write("<note>")
response.Write("<from>Jani</from>")
response.Write("<to>Tove</to>")
response.Write("<message>Remember me this weekend</message>")
response.Write("</note>")
%>
請注意,此回應的內容類型必須設置為 "text/xml"。
如果您想要學習 ASP,請在我們的首頁查找 ASP 教學。
通過 PHP 生成 XML
如需使用 PHP 從伺服器上生成 XML 回應,請使用下麵的代碼:
<?php
header("Content-type: text/xml");
echo "<?xml version='1.0' encoding='ISO-8859-1'?>";
echo "<note>";
echo "<from>Jani</from>";
echo "<to>Tove</to>";
echo "<message>Remember me this weekend</message>";
echo "</note>";
?>
header("Content-type: text/xml");
echo "<?xml version='1.0' encoding='ISO-8859-1'?>";
echo "<note>";
echo "<from>Jani</from>";
echo "<to>Tove</to>";
echo "<message>Remember me this weekend</message>";
echo "</note>";
?>
請注意,回應頭部的內容類型必須設置為 "text/xml"。
如果您想要學習 PHP,請在我們的首頁查找 PHP 教學。
從資料庫生成 XML
XML 可在不安裝任何 XML 軟體的情況下從資料庫生成。
如需從伺服器生成 XML 資料庫回應,只需簡單地編寫以下代碼,並把它在 Web 伺服器上保存為 ASP 檔:
<%
response.ContentType = "text/xml"
set conn=Server.CreateObject("ADODB.Connection")
conn.provider="Microsoft.Jet.OLEDB.4.0;"
conn.open server.mappath("/db/database.mdb")
sql="select fname,lname from tblGuestBook"
set rs=Conn.Execute(sql)
response.write("<?xml version='1.0' encoding='ISO-8859-1'?>")
response.write("<guestbook>")
while (not rs.EOF)
response.write("<guest>")
response.write("<fname>" & rs("fname") & "</fname>")
response.write("<lname>" & rs("lname") & "</lname>")
response.write("</guest>")
rs.MoveNext()
wend
rs.close()
conn.close()
response.write("</guestbook>")
%>
response.ContentType = "text/xml"
set conn=Server.CreateObject("ADODB.Connection")
conn.provider="Microsoft.Jet.OLEDB.4.0;"
conn.open server.mappath("/db/database.mdb")
sql="select fname,lname from tblGuestBook"
set rs=Conn.Execute(sql)
response.write("<?xml version='1.0' encoding='ISO-8859-1'?>")
response.write("<guestbook>")
while (not rs.EOF)
response.write("<guest>")
response.write("<fname>" & rs("fname") & "</fname>")
response.write("<lname>" & rs("lname") & "</lname>")
response.write("</guest>")
rs.MoveNext()
wend
rs.close()
conn.close()
response.write("</guestbook>")
%>
上面的實例使用了帶有 ADO 的 ASP。
如果您想要學習 ASP 和 ADO,請在我們的首頁查找相關教學。
在伺服器上通過 XSLT 轉換 XML
下麵的 ASP 代碼在伺服器上把 XML 檔轉換為 XHTML:
<%
'Load XML
set xml = Server.CreateObject("Microsoft.XMLDOM")
xml.async = false
xml.load(Server.MapPath("simple.xml"))
'Load XSL
set xsl = Server.CreateObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load(Server.MapPath("simple.xsl"))
'Transform file
Response.Write(xml.transformNode(xsl))
%>
'Load XML
set xml = Server.CreateObject("Microsoft.XMLDOM")
xml.async = false
xml.load(Server.MapPath("simple.xml"))
'Load XSL
set xsl = Server.CreateObject("Microsoft.XMLDOM")
xsl.async = false
xsl.load(Server.MapPath("simple.xsl"))
'Transform file
Response.Write(xml.transformNode(xsl))
%>
實例解釋
- 第一個代碼塊創建微軟 XML 解析器的實例(XMLDOM),並把 XML 檔載入記憶體。
- 第二個代碼塊創建解析器的另一個實例,並把 XSL 檔載入記憶體。
- 最後一個代碼使用 XSL 文檔來轉換 XML 文檔,並把結果以 XHTML 發送到您的流覽器。
通過 ASP 把 XML 保存為檔
這個 ASP 實例會創建一個簡單的 XML 文檔,並把該文檔保存到伺服器上:
<%
text="<note>"
text=text & "<to>Tove</to>"
text=text & "<from>Jani</from>"
text=text & "<heading>Reminder</heading>"
text=text & "<body>Don't forget me this weekend!</body>"
text=text & "</note>"
set xmlDoc=Server.CreateObject("Microsoft.XMLDOM")
xmlDoc.async=false
xmlDoc.loadXML(text)
xmlDoc.Save("test.xml")
%>
text="<note>"
text=text & "<to>Tove</to>"
text=text & "<from>Jani</from>"
text=text & "<heading>Reminder</heading>"
text=text & "<body>Don't forget me this weekend!</body>"
text=text & "</note>"
set xmlDoc=Server.CreateObject("Microsoft.XMLDOM")
xmlDoc.async=false
xmlDoc.loadXML(text)
xmlDoc.Save("test.xml")
%>