![]() |
Delphi-Version: 5
LoadXML() geht nicht nach Start durch ShellExecucte()
Hallo zusammen,
eine Anwendung beinhaltet folgende Funktion zum Lesen eines XML-formatierten Strings
Delphi-Quellcode:
Funktioniert alles wunderbar und so, wie's soll.
function TMDLizenz.CalcCheckSumFromString(const c:String): String;
var fsxml: IXMLDOMDocument2; cHash: String; begin result := ''; fsxml := CoDOMDocument.Create; fsxml.async := False; if fsxml.LoadXML( c ) then begin {Bestehende XML laden} recInsertNodes(fsxml.DocumentElement, cHash ); {String für SignaturHash rekursiv erstellen} result := self.DoSignatureLicense( cHash ); {MD5Hash über gesamte Lizenz erstellen} end; fsxml := nil; end; Aber wird diese XML-lesende Anwendung über ShellExecute aus einem anderen Prog. heraus aufgerufen (oder auch über CreateProcess, macht keinen Unterschied) und kommt dann an LoadXML(), fliegt mir alles zugriffsverletzt um die Ohren. Warum ist das so? Der String c ist in beiden Fällen identisch. Dank und Gruß Norbert |
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Zitat:
|
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Was steht in
Delphi-Quellcode:
?
c
Ich vermute jetzt einfach mal, daß du in
Delphi-Quellcode:
einen absoluten Pfadnamen übergeben solltest und keinen Relativen. :glaskugel:
c
|
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Zitat:
[ot]Aber die Formulierung ist geil :lol:[/ot] |
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Liste der Anhänge anzeigen (Anzahl: 1)
Genau so siehts aus. Zugriffsverletzung und fertig ... mom ... Screenie hängt an.
In c findet sich ein komplett zusammengesetzter xml-String. Mit allem was dazu gehört. Und der wird ja auch perfekt eingelesen, wenn die Anwendung "normal" gestartet wurde. Geschieht das aber wie oben geschildert, dann gibts den GPF. Gruss Norbert |
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Mal im Debugger geschaut, wo der Fehler genau auftritt?
|
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Welche Version von MSXML2 wird denn verwendet?
Meine Erfahrung ist, dass alles unterhalb von MSXML Version 4 SP2 relativ buggy ist. Ich habe auch schon festgestellt, dass .LoadXML() manchmal Erfolg meldet, obwohl das Dokument nicht geladen wurde.
Delphi-Quellcode:
Evtl. liegt das daran, dass die verknüpfte Schemadatei nicht geladen werden konnte.
if fsxml.LoadXML( c ) then begin {Bestehende XML laden}
// LoadXML() hat True zurückgegeben // trotzdem ist fsxml.DocumentElement = nil recInsertNodes(fsxml.DocumentElement, cHash ); // und dann knallt es hier ... end; |
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Zitat:
Zitat:
Ich werd den Verdacht nicht los, dass das Problem irgendwie in Richtung Prozesse, Threads oder ähnliches zu suchen ist. Es wirkt so, als wäre MSXML2 durch den ShellExecute/CreateProcess-Aufruf nicht richtig initialisiert worden. So was in der Art?! |
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Findet er die Datei eventuell nicht? Gib mal bei Shellexecute als Arbeitsverzeichnis das Verzeichnis an, wo die XML Datei liegt.
|
AW: LoadXML() geht nicht nach Start durch ShellExecucte()
Evtl. Leerzeichen im "Parameters"-Parameter von ShellExecute enthalten? Dann wird die Datei nämlich auch nicht gefunden. Das ist aber nur eine Vermutung, Genaueres kann man erst sagen, wenn man den ShellExecute-Aufruf einmal sieht.
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 11:43 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