Si la méthode Beautify ci-dessus est appelée pour un XmlDocument
qui contient déjà un XmlProcessingInstruction
nœud enfant, l'exception suivante est levée:
Impossible d'écrire la déclaration XML. La méthode WriteStartDocument l'a déjà écrite.
Ceci est ma version modifiée de l'original pour se débarrasser de l'exception:
private static string beautify(
XmlDocument doc)
{
var sb = new StringBuilder();
var settings =
new XmlWriterSettings
{
Indent = true,
IndentChars = @" ",
NewLineChars = Environment.NewLine,
NewLineHandling = NewLineHandling.Replace,
};
using (var writer = XmlWriter.Create(sb, settings))
{
if (doc.ChildNodes[0] is XmlProcessingInstruction)
{
doc.RemoveChild(doc.ChildNodes[0]);
}
doc.Save(writer);
return sb.ToString();
}
}
Cela fonctionne pour moi maintenant, vous auriez probablement besoin de scanner tous les nœuds enfants pour le XmlProcessingInstruction
nœud, pas seulement le premier?
Mise à jour avril 2015:
Depuis que j'ai eu un autre cas où le codage était incorrect, j'ai cherché comment appliquer UTF-8 sans BOM. J'ai trouvé ce billet de blog et créé une fonction basée sur celui-ci:
private static string beautify(string xml)
{
var doc = new XmlDocument();
doc.LoadXml(xml);
var settings = new XmlWriterSettings
{
Indent = true,
IndentChars = "\t",
NewLineChars = Environment.NewLine,
NewLineHandling = NewLineHandling.Replace,
Encoding = new UTF8Encoding(false)
};
using (var ms = new MemoryStream())
using (var writer = XmlWriter.Create(ms, settings))
{
doc.Save(writer);
var xmlString = Encoding.UTF8.GetString(ms.ToArray());
return xmlString;
}
}