데이터베이스에서 데이터를 읽고 XML 형식으로 데이터를 표시하지만 hd,category,subsort 등이 닫히지 않았습니다. 그런데 저는 이미 닫았습니다. 구체적으로 어떤 원인이 이 문제를 일으켰는지 모르겠습니다.VB code:
<%
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()
%>
출력된 내용에 <>'& 이 몇 개의 특수 문자를 사용할 수 없기 때문에 XmlEncode 인코딩이 필요합니다. 아래 코드 상세 정보: VBScript code:
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 “” 응답으로 변경합니다.write “” 또한 출력을 시작하기 전에 내용을 비워야 합니다: Response.Clear Response.write “” 또한: Response.write vbCrlf & vbTab & vbTab & "
"관찰하기 쉽습니다.