WD1X.COM - 问答一下,轻松解决,电脑应用解决专家
主板显卡CPU内存显示器
硬盘维修显卡维修显示器维修
注册表系统命令DOS命令Win8
存储光存储鼠标键盘
内存维修打印机维修
WinXPWin7Win11Linux
硬件综合机箱电源散热器手机数码
主板维修CPU维修键盘鼠标维修
Word教程Excel教程PowerPointWPS
网络工具系统工具图像工具
数据库javascript服务器
PHP教程CSS教程XML教程

报错“无法显示XML页”如何解决

更新时间:2012-12-05 15:10 作者:佚名点击:

昨天一位站长朋友联系到小编,问小编能不能解决从数据库读出数据中出现的问题,小编看了之后,给朋友解决了问题,下面我们就一起来看看小编对于报错“无法显示XML页”如何解决的吧。具体内容和报错如下:

--------------------
无法显示 XML 页。
使用 样式表无法查看 XML 输入。请更正错误然后单击 刷新按钮,或以后重试。
-------------------------------------------------------------------------

在我们从数据库读取数据,并以XML格式显示的时候,电脑就有提示出hd,category,subsort等没有关闭,但是经过小编的检查已经关闭了,所以问题不出在这里,那我们就一起来找找吧,首先看看源代码。

<%
response.ContentType= "text/xml"
Response.CharSet = "GB2312"
Response.Expires = 0
Response.write "<?xml version=""1.0"" encoding=""UTF-8"" ?>"
Response.write vbcrlf&"<hd>"
Response.write vbcrlf&vbTab&"<category>"
Response.write vbcrlf&vbTab&vbTab&"<subsort>"
‘连接数据库的语句省略
do while not rs.eof
response.write vbcrlf&vbTab&vbTab&vbTab&"<item>"
response.write vbcrlf&vbTab&vbTab&vbTab&vbTab&"<id>"&rs("id")&"</id>"
response.write vbcrlf&vbTab&vbTab&vbTab&"</item>"
loop
rs.close()
set rs=nothing
response.write vbcrlf&vbTab&vbTab&"</subsort>"
response.write vbcrlf&vbTab&"</category>"
response.write vbcrlf&"</hd>"
Response.End() 
%>

 

看了一下代码,小编发现代码中含有很多【 <> " ' & 】特殊符号,而真正在XML格式文件中,不能含有这些特殊符号,需要进行XmlEncode编码,改了之后我们在看看代码:

 

Function XMLEncode(var)
On Error Resume Next
Dim strTmp
If (IsNull(var)) Then
var = ""
End If
If (VarType(var) = 11) Then
If (var) Then
strTmp = "1"
Else
strTmp = "0"
End If
Else
strTmp = CStr(var)
strTmp = Replace(strTmp, "&", "&")
strTmp = Replace(strTmp, "<", "<")
strTmp = Replace(strTmp, ">", ">")
strTmp = Replace(strTmp, """", """)
strTmp = Replace(strTmp, "'", "'")
End If
XMLEncode = strTmp
End Function
Function XMLDecode(str)
Dim temp
temp=replace(str,"&","&")
temp=replace(temp,"<","<")
temp=replace(temp,">",">")
temp=replace(temp,""","""")
temp=replace(temp,"'","'")
XMLDecode = temp
End Function
Response.Write XmlEndode(rs("字段名字"))

 

 

除此之外,如果还有其他问题,我们还可以改动一下代码:

Response.write “<?xml version=”"1.0″” encoding=”"UTF-8″” ?>改成Response.write “<?xml version=”"1.0″” encoding=”"GB2312″” ?>

Response.Clear
Response.write “<?xml version=”"1.0″” encoding=”"GB2312″” ?>另外,写成Response.write vbCrlf & vbTab & vbTab & “<subsort>

将一些代码改成这样,更利于我们观察,同时也更好的显示出来。

以上就是关于报错“无法显示XML页”如何解决的办法,希望对大家有所帮助。

顶一下
(1)
100%
踩一下
(0)
0%
------分隔线----------------------------
你可能感兴趣的内容