System.Xml.XmlException: The reference to entity must end with the ';' delimiter.: what it means and how to fix it
Troubleshoot System.Xml.XmlException: The reference to entity must end with the ';' delimiter. and fix invalid XML locally (no upload).
What the error means
System.Xml.XmlException: The reference to entity must end with the ';' delimiter. means the XML parser found invalid markup. Most XML issues are fixable by correcting the first broken tag/character and re-validating.
Most common real-world causes
- Mismatched tags (opening/closing tags do not match).
- Unescaped reserved characters (especially & in text).
- Multiple root elements (XML must have exactly one root).
- Invalid characters (control chars, bad Unicode) inside the file.
- Wrong encoding or a stray BOM/prolog mismatch.
- Cut/truncated XML (missing closing tags).
Fast debugging steps
- Validate the first error first. Fixing the first broken tag usually resolves many downstream errors.
- Search around the reported line/column for mismatched tags or a raw '&' that should be '&'.
- Confirm the XML starts with a single root and ends with the matching closing tag.
- If the file comes from a feed/export, try a smaller sample to isolate the first invalid record.
Code example (csharp)
using System;
using System.Xml;
try {
var doc = new XmlDocument();
doc.LoadXml(xmlText);
Console.WriteLine(doc.DocumentElement?.Name);
} catch (XmlException e) {
Console.WriteLine(e.Message);
Console.WriteLine($"Line={e.LineNumber} Position={e.LinePosition}");
}
Fix without uploading data
If the XML contains sensitive data, validate and convert locally. No Upload Tools runs 100% in your browser.
- XML to JSON to trigger strict parsing and see the first parser error.
- JSON Validator to validate output if you post-process to JSON.
Workflow: validate -> fix the first error -> validate again -> export/convert.
FAQ
Why do I get different errors in different tools? XML parsers differ. Always fix the first error in the raw input and re-check.
Should I regex-fix XML? Avoid blind regex edits. Validate after each change so you know what you fixed.
Related by intent
Closest pages and hubs to accelerate crawl discovery and first impressions.