Visual Basic Code (schemaLocation.frm)
This topic provides Visual Basic code.
Try It!
Copy the first XML data file from the resource files, and paste it into a text file. Save the file as sl-valid.xml.
Copy the second XML data file from the resource files, and paste it into a text file. Save the file as sl-notValid.xml, in the same directory where you saved sl-valid.xml.
Copy the XSD schema file from the resource files, and paste it into a text file. Save the file as sl.xsd, in the same directory you used in previous steps.
Create a Standard EXE project in Visual Basic. Save the empty project as schemaLocation.vbp to the same directory you used in previous steps. Name and save the form file as schemaLocation.frm.
Create a reference to MSXML 6.0. To do this, select References... from the Project menu, and then check the box for Microsoft XML, v6.0.
Copy the Visual Basic code listing above, and paste it into the Visual Basic code editor to replace whatever code is already there.
Execute the code by selecting Start from the Run menu.
Verify that your output is the same as that listed in the output for this example.
schemaLocation.frm
Private Sub Form_Load()
Dim sOutput As String
sOutput = ValidateFile("sl-valid.xml")
sOutput = sOutput & ValidateFile("sl-notValid.xml")
MsgBox sOutput
Unload Me
End Sub
Function ValidateFile(strFile As String)
'Create an XML DOMDocument object.
Dim x As New DOMDocument60
' Set first-level DOM properties.
x.async = False
x.validateOnParse = True
x.resolveExternals = True
' Configure DOM properties for namespace selection.
x.setProperty "SelectionLanguage", "XPath"
ns = "xmlns:x='urn:book'"
x.setProperty "SelectionNamespaces", ns
' Load and validate the specified file into the DOM.
x.Load App.Path & "\" & strFile
' Return validation results in message to the user.
If x.parseError.errorCode <> 0 Then
ValidateFile = "Validation failed on " & _
strFile & vbCrLf & _
"=====================" & vbCrLf & _
"Reason: " & x.parseError.reason & _
vbCrLf & "Source: " & _
x.parseError.srcText & _
vbCrLf & "Line: " & _
x.parseError.Line & vbCrLf
Else
ValidateFile = "Validation succeeded for " & _
strFile & vbCrLf & _
"======================" & _
vbCrLf & x.xml & vbCrLf
End If
End Function