![]() |
Daten übertragen von DLL nach EXE
Hallo DP'ler,
ich möchte Daten von einer DLL in die HostApplication senden. Dafür nutze ich Code, den ich hier im Forum gefunden habe, aber leider noch nicht so recht verstehe. :drunken: Die Struktur die übertragen werden soll:
Delphi-Quellcode:
Die DLL sendet die Struktur so:
type
PcsCopyDataStruct = ^TcsCopyDataStruct; TcsCopyDataStruct = packed record dwData : DWORD; cbData : DWORD; lpData : Pointer; end;
Delphi-Quellcode:
und zum Empfangen in der Hostanwendung überscheibe die die WndProc so:
procedure fSendMsg(pHwnd : HWND); stdcall;
var dwMsg : DWORD; cdWork : TcsCopyDataStruct; sDummyStr : string; begin dwMsg := RegisterWindowMessage('{6A64733D-6DAE-4972-9668-0181419AE58D}'); sDummyStr := ('Delphi-Praxis ist super!'); cdWork.dwData := dwMsg; cdWork.cbData := Length(sDummyStr)+1; cdWork.lpData := AllocMem(cdWork.cbData); try CopyMemory(cdWork.lpData,@sDummyStr[1],cdWork.cbData-1); sendMessage(pHwnd,WM_COPYDATA,dwMSg,lParam(@cdWork)); // [color=#ff0000]<- Stürtz ab[/color] //PostMessage(pHwnd,WM_COPYDATA,dwMSg,lParam(@cdWork)); // [color=#ff0000]<- Msg kommt nicht an[/color] finally FreeMem(cdWork.lpData,cdWork.cbData); end; end;
Delphi-Quellcode:
Aufgerufen wird das ganz so:
procedure TForm1.WndProc(var msg : TMessage);
var cdWork : PcsCopyDataStruct; begin if msg.Msg = WM_COPYDATA then begin if msg.WParam = dwMsg then begin cdWork := PcsCopyDataStruct(msg.lParam); showMessage (pchar(cdWork.dwData)); end else // Jede andere Message an die ursprüngliche Prozedure weiterreichen inherited WndProc(msg); end else // Jede andere Message an die ursprüngliche Prozedure weiterreichen inherited WndProc(msg); end;
Delphi-Quellcode:
Das SendMessge in der DLL führt zu einer Schutzverletzung und PostMessage scheint garnicht erst anzukommen, aber wieso?
procedure TForm1.Button1Click(Sender: TObject);
begin dwMsg := RegisterWindowMessage('{6A64733D-6DAE-4972-9668-0181419AE58D}'); fSendMsg(Form1.Handle); end; Ich nutze diese Code auch an anderer Stelle und dort funktioniert er. Gibt es beim Senden aus DLL's noch etwas zu beachten? Oder hab ich was übersehen? Könnt ihr helfen? Sicher hat es was mit geschützten Speicherbereichen zu tun. Wäre net wenn ihr mir das erklären könntet. Gruß und Danke gmc |
Re: Daten übertragen von DLL nach EXE
Delphi-Quellcode:
??
procedure TForm1.Button1Click(Sender: TObject);
begin dwMsg := RegisterWindowMessage('{6A64733D-6DAE-4972-9668-0181419AE58D}'); fSendMsg(Form1.Handle); end; Vielleicht nur so:
Delphi-Quellcode:
In fSendMsg wird
procedure TForm1.Button1Click(Sender: TObject);
begin fSendMsg(Form1.Handle); end;
Delphi-Quellcode:
sowieso aufgerufen.
dwMsg := RegisterWindowMessage('{6A64733D-6DAE-4972-9668-0181419AE58D}');
edit: Ich denke dwMsg sollte global/ als public Feld von TForm1 deklariert sein. |
Re: Daten übertragen von DLL nach EXE
Ähm, viellicht ist es nicht korrekt rüber gekommen.
Die HostAnwendung und die DLL sind zwei getrennte Applicationen. Also muß ich dwMsg in beiden Applicationen mit RegisterWindowMessage auf den gleichen Wert setzen. Oder etwa nicht? :gruebel: Jedenfalls funktioniert ein
Code:
nur so. Und das kommt sogar in der Hostanwendung an,aber
PostMessage(pHwnd,WM_COPYDATA,dwMsg,0);
Code:
funktioniert nicht.
PostMessage(pHwnd,WM_COPYDATA,dwMSg,lParam(@cdWork));
Hmm ... Keiner ne Idee? |
Re: Daten übertragen von DLL nach EXE
Hallo Ihr,
ich möchte das Thema mal wieder aufwerfen. Ich hab mir dem Code nochmal genauer angeschaut und mir ist in meiner Beschreibung damals, ein Fehler unterlaufen. Die Schutzverletzung kommt nich in der DLL sondern in der Hostanwendung. Diese meint, das ein Zugriffsverletzung im "Host"-Modul beim Lesen auf der Adresse 000000C (oder so ähnlich) passiert sein. Im Code wäre es diese Zeile der Hostanwendung
Delphi-Quellcode:
Ok, die Adresse 0000000C sieht mMn auch komisch aus.
cdWork := PcsCopyDataStruct(msg.lParam);
Was mache ich falsch? Um Hilfe bittend... gmc |
Re: Daten übertragen von DLL nach EXE
Ähem ... eines müßtet ihr mir mal kurz erklären: "von einer DLL in die HostApplication senden" klingt stark danach, daß unsere DLL in die Anwendung (APP) geladen ist?! Ist das so?
Warum wird dann überhaupt alles "gesendet"? Die DLL teilt sich doch mit ebendiesem Prozeß auch den Speicherraum. Man kann also einfach Pointer und Größe übergeben und muß nicht so tun als wäre es eine echte IPC. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:35 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