Solved

Need to check that XML file has the right structure

Posted on 2006-11-29
8
193 Views
Last Modified: 2013-11-19
I am writing a small application that generates unique codes for me. As I do not whish to have duplicates I want to make use of an xml file to store the generated codes for checking against any newly created codes.

I want to be able to assign the xml file that is used for the checking and as such have to validate that the file contains the correct xml.

I have created an XSD file and tried to validate it that way, but it does not seem to work. I intentionally use an incorrect xml file yet it validates.

This is the xsd file:

<?xml version="1.0" encoding="utf-8"?>
<xs:schema id="XSDSchema1" targetNamespace="http://tempuri.org/XSDSchema1.xsd" elementFormDefault="qualified" xmlns="http://tempuri.org/XSDSchema1.xsd" xmlns:mstns="http://tempuri.org/XSDSchema1.xsd" xmlns:xs="http://www.w3.org/2001/XMLSchema">
  <xs:complexType name="machineKeys">
    <xs:sequence>
      <xs:element name="machinekey" minOccurs="0">
        <xs:complexType>
          <xs:sequence>
            <xs:element name="validationKey" minOccurs="1" maxOccurs="1">
              <xs:simpleType>
                <xs:restriction base="xs:string">
                  <xs:pattern value="^[A-Za-z0-9]{128}$" />
                </xs:restriction>
              </xs:simpleType>
            </xs:element>
            <xs:element name="decryptionKey">
              <xs:simpleType>
                <xs:restriction base="xs:string">
                  <xs:pattern value="^[A-Za-z0-9]{48}$" />
                </xs:restriction>
              </xs:simpleType>
            </xs:element>
          </xs:sequence>
        </xs:complexType>
      </xs:element>
    </xs:sequence>
  </xs:complexType>
</xs:schema>

Here is the code that is supposed to validate the xml file:

If ofd.ShowDialog = Windows.Forms.DialogResult.OK Then
      Try
        Dim rdr = New XmlTextReader(ofd.FileName)
        Dim sr As StreamReader = New StreamReader(AppDomain.CurrentDomain.BaseDirectory & "MachineKeys.xsd")
        Dim sch As XmlSchema = New XmlSchema

        sch = XmlSchema.Read(sr, New ValidationEventHandler(AddressOf ValidationEventHandler))
        Dim rdrSettings As XmlReaderSettings = New XmlReaderSettings
        rdrSettings.ValidationType = ValidationType.Schema
        rdrSettings.Schemas.Add(sch)

        AddHandler rdrSettings.ValidationEventHandler, New ValidationEventHandler(AddressOf ValidationEventHandler)

        Dim objXmlReader As XmlReader = XmlReader.Create(rdr, rdrSettings)

        While objXmlReader.Read
        End While
      Catch ex As Exception
        MsgBox("Error: " & ex.Message, MsgBoxStyle.Critical, "Machine Key Generator")
      End Try
End If

Private Sub ValidationEventHandler(ByVal sender As Object, ByVal e As Xml.Schema.ValidationEventArgs)
    Select Case e.Severity
      Case Xml.Schema.XmlSeverityType.Error
        _xmlValidationOutcome &= "Error: " & e.Message & vbNewLine
      Case Xml.Schema.XmlSeverityType.Warning
        _xmlValidationOutcome &= "Warning {0}" & e.Message & vbNewLine
    End Select
End Sub

PS: The XSD file is created if not found.
0
Comment
Question by:Adsony
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 4
  • 4
8 Comments
 
LVL 3

Expert Comment

by:EverLearningCodeMonkey
ID: 18036929
Hi Adsony,

I havnen't taken too close a look at your code but I have looked at your XML and ran it through a couple of online validators (<a href="http://www.w3schools.com/dom/dom_validate.asp">http://www.w3schools.com/dom/dom_validate.asp</a> and <a href="http://www.w3.org/2001/03/webdata/xsv">http://www.w3.org/2001/03/webdata/xsv</a> respectively) and the XML (at least what you posted IS valid, at least according to them.

I guess what I'm wondering is what you mean in terms of validation?  Structurally the XML is fine, whether the data that it contains is what your application wants/needs may be another matter entirely.  

From what I gather from the code you posted, it's evaluating the structure of the XML document.  To validate for application specific information I think you'll have to navigate your way through the nodes and check it that way.

Hope this helps.
0
 

Author Comment

by:Adsony
ID: 18037207
Hi EverLearningCodeMonkey.

The XSD document is fine yes. What I want to do is take any xml document and check that it looks like what that xsd file sais it should.

For example: If i pass it a xml document that looks like -
<contactlist>
  <contact>
    <name>John Doe</name>
    <number>555123456</number>
  </contact>
</contactlist>

 - I want the validator fail the document. Only xml documents that look like what that xsd doc says should pass.
0
 
LVL 3

Expert Comment

by:EverLearningCodeMonkey
ID: 18038382
Ah, Gotcha.

I'll admit I'm not terribly familiar with XSD and document validation, I did however come across this article on MSDN, http://msdn2.microsoft.com/en-us/library/as3tta56.aspx - I'm not sure if it's equivalent to what you're using already but it may be worth taking a look at.  

It implements XmlSchemaSet to act as a library that caches the schemas to improve performance.  The code looks to be pretty similar to what you're using - I have noticed some minor differences in how some of the calls are made in the example vs how you have them, might be worth looking into as well.
0
Resolve Critical IT Incidents Fast

If your data, services or processes become compromised, your organization can suffer damage in just minutes and how fast you communicate during a major IT incident is everything. Learn how to immediately identify incidents & best practices to resolve them quickly and effectively.

 

Author Comment

by:Adsony
ID: 18043420
Read my original post. Then read my code.

First you told me something I already knew: my XSD schema is fine. Then you point me to some code that does exactly what my code is doing. This is not helping.
0
 
LVL 3

Accepted Solution

by:
EverLearningCodeMonkey earned 500 total points
ID: 18045515
Hi Adsony,

I have read your original post and your code.  The first time around I admit I misunderstood.  My second post was to point you to some test bed code.  It's a working example that you can test, as I have this morning.  It works just fine with the data for the example.

My point in suggesting it was to provide a scenario to compare and contrast what you've written yourself.  If your code produces the same results as the example then all is well with what you've written and then you can focus other things that are possibly causing problems.

I ran both the MSDN sample and your code side by side and they both produce the same results.  So your code is fine too.   Given your previous post I have a mental image of you screaming "THAT DOESN'T HELP EITHER!" - I would contend that it does help as it removes your code as the potential problem.  The next logical step is to turn to the XML and XSD files themselves and start messing with copies of them.

I can recreate the scenario that you describe where you run an XML document through the validation and it should fail but it doesn't.  If the XML document I'm trying to validate doesn't have the same targetNamespace as the schema or is devoid of one then it generates no errors.  If the correct targetNamespace is specified then it will validate the file properly.

So, at least from where I'm standing, the focus would now be how to get the validator to recognize that the namespace is wrong or missing.  After a little playing around with the properties of the objects I've found that the XmlReader object has a property called NamespaceURI which is a string that has the namespace in it - apparently you need to start reading the document in order to get this property but it is there.  The XmlSchema object has a similar property called TargetNamespace (also returns a string), you could do a simple string comparison as a means of checking namespaces and throwing an exception if they don't match or if the NamespaceURI property is missing.

I think that should just about do it.
0
 

Author Comment

by:Adsony
ID: 18045637
Now that's what I was looking for. Sounds like you are onto the answer there. I'll test it tomorow, my pc crashed so I'm doing search and rescue at the moment. I will let you know how it turns out. Thank you for the effort.
0
 
LVL 3

Expert Comment

by:EverLearningCodeMonkey
ID: 18045751
No Problem - Good luck with your search and rescue efforts

ELCM
0
 

Author Comment

by:Adsony
ID: 18099994
I have not had a chance to check the above solution out yet. I have other projects that are keeping me busy. It sounds like it could just do the trick so I'm not going to string EverLearningCodeMonkey along until I can spare some time to actually try it. I therefore award the points to him. I'll post the outcome once I have a chance.
0

Featured Post

Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Create .bat File 16 73
MediaWiki - Move a site 4 32
How to build a web site 17 57
Convert VB web project to C# 3 39
In this post we will learn different types of Android Layout and some basics of an Android App.
Real-time is more about the business, not the technology. In day-to-day life, to make real-time decisions like buying or investing, business needs the latest information(e.g. Gold Rate/Stock Rate). Unlike traditional days, you need not wait for a fe…
Viewers will learn how to properly install Eclipse with the necessary JDK, and will take a look at an introductory Java program. Download Eclipse installation zip file: Extract files from zip file: Download and install JDK 8: Open Eclipse and …

733 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question