Mam następujący kod:Podczas zapisywania XmlDocument, ignoruje kodowanie w XmlDeclaration (UTF-8) i wykorzystuje UTF16
var doc = new XmlDocument();
XmlDeclaration xmlDeclaration = doc.CreateXmlDeclaration("1.0", "UTF-8", null);
doc.AppendChild(xmlDeclaration);
XmlElement root = doc.CreateElement("myRoot");
doc.AppendChild(root);
root.InnerText = "myInnerText";
StringWriter sw = new StringWriter();
doc.Save(sw);
Console.WriteLine(sw.ToString());
Console.WriteLine();
MemoryStream ms = new MemoryStream();
doc.Save(ms);
Console.WriteLine(Encoding.ASCII.GetString(ms.ToArray()));
I tu jest wyjście:
<?xml version="1.0" encoding="utf-16"?>
<myRoot>myInnerText</myRoot>
???<?xml version="1.0" encoding="UTF-8"?>
<myRoot>myInnerText</myRoot>
Zasadniczo co go robi plik xml i ustawia kodowanie na utf8, ale kiedy zapisuje go do stringwriter, ignoruje moje kodowanie i używa utf16. Jednak podczas korzystania ze strumienia pamięci używa on utf8 (z dodatkowymi znakami BOM).
Dlaczego tak jest? Dlaczego nie honoruje mojego jawnego ustawienia kodowania dla utf-8?
Thanks a lot
tylko ciekaw, czy spróbować dając zerowy/string. pusty w kodowaniu i patrz? – user281693
Jeśli to zrobię, stringwriter nadal będzie utf16, a komunikat memorystrujący nie będzie zawierał kodowania w deklaracji. – Chris
np. Wygląda to tak: xml version = "1.0"?> – Chris