AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Projekte himXML (gesprochen himix ML)
Thema durchsuchen
Ansicht
Themen-Optionen

himXML (gesprochen himix ML)

Ein Thema von himitsu · begonnen am 12. Mär 2009 · letzter Beitrag vom 11. Nov 2020
Antwort Antwort
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.167 Beiträge
 
Delphi 10 Seattle Professional
 
#1

AW: himXML (gesprochen himix ML)

  Alt 6. Dez 2012, 17:28
Ich fange wie immer an mit dem großen Lob an den Autor

Habe gestern etwas entdeckt, was ich mir nicht erklären kann.
Und zwar setze ich himXML bei der Verarbeitung von sehr großen Mengen an XML-Daten ein, die ich von einer API geliefert bekomme. Bei der Auswertung der Log-Datei habe ich nun mehrere Exceptions von himXML entdeckt die wie folgt aussehen:

[EXMLException] TXMLFile.LoadFromXML:
invalid value ("<?xml version=#00221.0#22 encoding=#22UTF-8#22?><epart:epart xmlns...")

TXMLFile.LoadFromStream:
invalid value

TXMLFile.-:


Wenn man bedenkt, dass am Tag über 200.000 Datensätze verarbeitet werden, sind paar Hundert solche Exeptions nicht weiter schlimm. Ich würde aber gerne verstehen, warum diese Fehler auftretten. Ich habe mit den Technikern des API-Betreibers telefoniert, die ihrerseits ein Fehler im XML-Header ausschließen. Schließlich kommen andere Daten mit dem richtigen Header an, der Header sei doch nur eine String-Konstante, die den zu versendenden Daten zugefügt wird. Daraufhin habe ich die Protokollierung etwas erweitert und füge nun auch den gesammte von der API gelieferte XML-String mit ein. Und spätestens dort ist sichtbar, dass der Header korrekt ist:

[EXMLException] TXMLFile.LoadFromXML:
invalid value ("<?xml version=#00221.0#22 encoding=#22UTF-8#22?><epart:epart xmlns...")

TXMLFile.LoadFromStream:
invalid value

TXMLFile.-:

Server data:

<?xml version="1.0" encoding="UTF-8"?><epart:epart xmlnssi="http://www.w3.org/2001/XMLS...


Warum passiert das? Hat jemand eine Erklärung?

Geändert von romber ( 6. Dez 2012 um 18:23 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Garfield
Garfield

Registriert seit: 9. Jul 2004
Ort: Aken (Anhalt-Bitterfeld)
1.335 Beiträge
 
Delphi XE5 Professional
 
#2

AW: himXML (gesprochen himix ML)

  Alt 7. Dez 2012, 22:37
... Und spätestens dort ist sichtbar, dass der Header korrekt ist:
Wirklich?

invalid value ("<?xml version=#00221.0#22 encoding=#22UTF-8#22?><epart:epart xmlns...")
Die Quotation ist unterschiedlich. Das erste Hochkomma ist #0022, die anderen sind #22.
Gruss Garfield
Ubuntu 22.04: Laz2.2.2/FPC3.2.2 - VirtBox6.1+W10: D7PE, DXE5Prof
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.167 Beiträge
 
Delphi 10 Seattle Professional
 
#3

AW: himXML (gesprochen himix ML)

  Alt 7. Dez 2012, 22:51
Die Quotation ist unterschiedlich. Das erste Hochkomma ist #0022, die anderen sind #22.
Das ist nicht zu übersehen. Die empfangene Daten (s. unten) sind aber richtig und enthalten weder #0022 noch #22 im Header.
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: himXML (gesprochen himix ML)

  Alt 7. Dez 2012, 23:11
Die Quotation ist unterschiedlich. Das erste Hochkomma ist #0022, die anderen sind #22.
Das ist nicht zu übersehen. Die empfangene Daten (s. unten) sind aber richtig und enthalten weder #0022 noch #22 im Header.
Das unten ist aber eine Interpretation (für die Anzeige) der Daten. Schau dir die empfangenen Daten per HexEditor an.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.167 Beiträge
 
Delphi 10 Seattle Professional
 
#5

AW: himXML (gesprochen himix ML)

  Alt 7. Dez 2012, 23:49
Das unten ist aber eine Interpretation (für die Anzeige) der Daten. Schau dir die empfangenen Daten per HexEditor an.
Das untere Teil füge ich selbst hinzu und es entspicht genau den Daten, die ich geliefert bekomme. Z.B. so:

Delphi-Quellcode:
var
  XMLResponse: string;
  XMLData: TXMLFile;
  ResultsCount: integer;
begin
  XMLData := TXMLFile.Create;
  XMLResponse := {Request};
  try
    XMLData.LoadFromXML(XMLResponse);
    ResultsCount := XMLData.RootNode.Nodes.Count;
  except
    On E: Exception do
    StoreException(E.Message + #13#10#13#10 + XMLResponse);
  end;
  XMLData.Free;
end;
Wie man sieht, es handelt sich genau um desselben String, den ich in den XML-Object geladen bekommen möchte.
  Mit Zitat antworten Zitat
Benutzerbild von Garfield
Garfield

Registriert seit: 9. Jul 2004
Ort: Aken (Anhalt-Bitterfeld)
1.335 Beiträge
 
Delphi XE5 Professional
 
#6

AW: himXML (gesprochen himix ML)

  Alt 8. Dez 2012, 00:41
#0022 ist nicht gleich #22. Mein Vorschlag wäre, mal testweise im String XMLResponse #0022 durch #22 zu ersetzen.
Gruss Garfield
Ubuntu 22.04: Laz2.2.2/FPC3.2.2 - VirtBox6.1+W10: D7PE, DXE5Prof
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#7

AW: himXML (gesprochen himix ML)

  Alt 8. Dez 2012, 00:50
Das unten ist aber eine Interpretation (für die Anzeige) der Daten. Schau dir die empfangenen Daten per HexEditor an.
Das untere Teil füge ich selbst hinzu und es entspicht genau den Daten, die ich geliefert bekomme. Z.B. so:

Delphi-Quellcode:
var
  XMLResponse: string;
  XMLData: TXMLFile;
  ResultsCount: integer;
begin
  XMLData := TXMLFile.Create;
  XMLResponse := {Request};
  try
    XMLData.LoadFromXML(XMLResponse);
    ResultsCount := XMLData.RootNode.Nodes.Count;
  except
    On E: Exception do
    StoreException(E.Message + #13#10#13#10 + XMLResponse);
  end;
  XMLData.Free;
end;
Wie man sieht, es handelt sich genau um desselben String, den ich in den XML-Object geladen bekommen möchte.
Und wie erklärst du dir die #0022 in der E.Message? Die kommt da nicht hin, weil deiner CPU gerade langweilig war.
#0022 ist nicht gleich #22. Mein Vorschlag wäre, mal testweise im String XMLResponse #0022 durch #22 zu ersetzen.
einmal mit StringReplace drüberbügeln und testen
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
romber

Registriert seit: 15. Apr 2004
Ort: Köln
1.167 Beiträge
 
Delphi 10 Seattle Professional
 
#8

AW: himXML (gesprochen himix ML)

  Alt 8. Dez 2012, 01:04
Und wie erklärst du dir die #0022 in der E.Message?
Kann ich mir nicht erklären. Das war auch meine Frage. TXMLFile liefert doch die Fehlermeldung. Das untere Teil ist nur da, um zu zeigen, dass die Daten in Ordnung sind.

Die kommt da nicht hin, weil deiner CPU gerade langweilig war.
Da bin ich mir gar nicht mehr sicher. Wenn ich iem selben Except-Abschnitt erneut versuche, dieselben Daten in die TXMLFile zu laden, klappt's wundebar.

einmal mit StringReplace drüberbügeln und testen
Habe ich schon. Es gibt aber keine #0022 und #22 im String.
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

(?)

LinkBack to this Thread

Erstellt von For Type Datum
xml - MSXML alternative - Stack Overflow This thread Refback 28. Jun 2011 15:34

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:57 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz