![]() |
Named Pipes - mitlesen
Hallo,
ich hab hier ein Programm, das kommuniziert über RS232, gibt diese Daten dann per Named Pipes an andere Prozesse weiter. Mittlerweile habe ich es geschafft die Named Pipe mitzulesen, ich erhalte jedoch immer nur unvollständige Informationen. ich vermute es liegt an dem eingesetzten Timer, der nach Ablauf den Buffer neu füllt und nichtaufgezeichnete Daten überschreibt. Aber wie macht man das denn ??? Folgenden Code verwende ich zur Zeit:
Delphi-Quellcode:
Jemand eine Idee wie ich die Pipe komplett mitschneiden kann ?procedure TForm2.FormCreate(Sender: TObject); var FSA : SECURITY_ATTRIBUTES; FSD : SECURITY_DESCRIPTOR; begin Timer1.Enabled:=false; Memo1.Clear; InitializeSecurityDescriptor(@FSD, SECURITY_DESCRIPTOR_REVISION); SetSecurityDescriptorDacl(@FSD, True, nil, False); FSA.lpSecurityDescriptor := @FSD; FSA.nLength := sizeof(SECURITY_ATTRIBUTES); FSA.bInheritHandle := True; Pipe:= CreateFile(PChar('\\.\pipe\Output'), GENERIC_READ or GENERIC_WRITE, 0, @FSA, OPEN_EXISTING, 0, 0); end; procedure TForm2.Timer1Timer(Sender: TObject); begin Button1Click(self); end; procedure TForm2.Button1Click(Sender: TObject); var buffer: shortstring; dw : dword; begin Timer1.enabled:=true; ReadFile(Pipe, buffer, sizeof(buffer), dw, nil); Memo1.Lines.Add(buffer); end; KUBA |
Re: Named Pipes - mitlesen
Du überschreibst das Längenbyte des Shortstrings, wodurch der String abgeschnitten wird. Du darfst buffer[0] nicht überschreiben. Du kannst dann buffer[0] := dw setzen.
Übrigens kannst du dir das Herumgetüftele mit den Security Attributes sparen. Setze einfach nil für den Parameter ein; nur beim Ersteller wird die Information überhaupt ausgewertet. |
Re: Named Pipes - mitlesen
Das verstehe ich nicht wirklich, wie soll das denn aussehen ?
etwa so ?
Delphi-Quellcode:
kuba
buffer[0] := dw;
ReadFile(Pipe, buffer[0], sizeof(buffer), dw, nil); |
Re: Named Pipes - mitlesen
Nachdenken! Welchen Wert hat dw vor dem Aufruf von ReadFile? Warum überschreibst du noch immer buffer[0]?
|
Re: Named Pipes - mitlesen
welchen Wert dw vor ReadFile hat ? Undefiniert, oder ?
Wieso überschreibe ich den buffer ? Ich fange doch bei 0 an (buffer[0]) und will dann die Länge ausgeben (sizeof(buffer)). Verstehe nicht :pale: kubaa |
Re: Named Pipes - mitlesen
Undefiniert, eben. buffer[0] := dw also nach dem ReadFile.
Zitat:
|
Re: Named Pipes - mitlesen
moment mal, habe ich nach READFILE nicht die Anzahl der gelesenen Bytes in dw ??
Bei buffer[0] := dw; sagt der Compiler [Fehler] client.pas(45): E2010 Inkompatible Typen: 'Char' und 'Cardinal' Müsste es nicht dw:=0 sein ? kuba |
Re: Named Pipes - mitlesen
Zitat:
Fein erkannt. Daher soll ja das Längenbyte des Shortstrings überhaupt erst den Wert dw erhalten. Du kannst übrigens ganz unbesorgt nach Char casten. |
Re: Named Pipes - mitlesen
ein ShortString hat an erster Stelle ein LängenByte, welches die Länge des Strings innerhalb dessen Speichers angibt.
Das ist auch ein/der Grund, warum der Delphi-String, wegen der Abwärtskompatibilität und aus Gewohnheitsgründen (wenn man das jetzt auf 0 ändert, müßten bestimmt 95% der Delphi-Anwendungen überabeitet werden), ebenfalls mit 1 beginnt, obwohl es dort dieses Längenbyte nicht mehr in dieser Form gibt.
Delphi-Quellcode:
ReadFile(Pipe, buffer[1], 255, dw, nil);
buffer[0] := AnsiChar(dw); // aka SetLength(buffer, dw); |
Re: Named Pipes - mitlesen
Supi, ich habs jetzt:
Delphi-Quellcode:
Jetzt hab ich nur gelegentlich Zeilen mit Zeichen die nicht in der Pipe sind. Vermutlich genau dann, wenn die Pipe gerade bedient wird und mein Timer eine Abfrage startet.
procedure TForm2.Button1Click(Sender: TObject);
var buffer: shortstring; dw : dword; begin Timer1.enabled:=true; ReadFile(Pipe, buffer[0], sizeof(buffer), dw, nil); buffer[0] := Char(dw); Memo1.Lines.Add(buffer); end; kuba |
Re: Named Pipes - mitlesen
ReadFile + buffer[1] !
daher könnte auch ein unbestimmtes Zeichen am Ende des Strings stammen und ein fehlendes Zeichen am Anfang des Strings :angel2: [add] und dann auch nicht SizeOf(Buffer), sondern High(Buffer) ! (beim ShortString gibt High den höchstmöglichen Zeichenindex und somit die Maximallänge an) |
Re: Named Pipes - mitlesen
Ja, tatsächlich. Jetzt hab ich die Daten komplett !
Delphi-Quellcode:
thanx ! :thumb:
procedure TForm2.Button1Click(Sender: TObject);
var buffer: shortstring; dw : dword; begin Timer1.enabled:=true; ReadFile(Pipe, buffer[1], high(buffer), dw, nil); buffer[0] := Char(dw); Memo1.Lines.Add(buffer); end; kuba |
Re: Named Pipes - mitlesen
nimm aber besser statt dem char(dw) eine der beiden Möglichkeiten
Delphi-Quellcode:
bei SetLength weiß man vielleicht in jahren noch, was gemeint ist
buffer[0] := AnsiChar(dw);
SetLength(buffer, dw); und das mit dem AnsiChar ... nja, ab Delphi 2009 ist Char ein WideChar, aber ShortString bleibt Ansi und dann gibt es Probleme wegen dem Unicode-zu-Ansi. |
Re: Named Pipes - mitlesen
Zitat:
Delphi-Quellcode:
kuba
procedure TForm2.Button1Click(Sender: TObject);
var buffer: shortstring; dw : dword; begin Timer1.enabled:=true; ReadFile(Pipe, buffer[1], high(buffer), dw, nil); SetLength(buffer, dw); //buffer[0] := PAnsiChar(dw); Memo1.Lines.Add(buffer); end; |
Re: Named Pipes - mitlesen / event filtern
Hallo,
ich möchte in meinem buffer noch ein event filtern, das sieht so aus: ?C*PU00000B8F Dabei ist ?C*PU das Event und 00000B8F die Value in HEX. Kann mir wohl nochmal jemand auf die Sprünge helfen, mit dem buffer hab ich´s nicht so :cyclops: kuba |
Re: Named Pipes - mitlesen
|
Re: Named Pipes - mitlesen
ja genau, copy ...
kuba |
Re: Named Pipes - mitlesen
Hallo,
sch..ade, ich komm nich drauf :pale: dies sollte doch eigentlich funktionieren:
Delphi-Quellcode:
aber es kommt nur müll :glaskugel:
if Pos('?C*PU',buffer) > 0 then
Edit1.Text:=copy(buffer,(pos('?C*PU',buffer)+5),8); kuba |
Alle Zeitangaben in WEZ +1. Es ist jetzt 15:36 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