FindWindow in einem Service unter Vista
Hi.
Hier ist mein Code:
Delphi-Quellcode:
Es funktioniert in einer normalen Application (sowohl vista als auch xp).
procedure SendMessageToWindow(msg: LongWord;value:longword=0);
var Wnd: THandle; begin Wnd := FindWindow('myClass', NIL); if Wnd > 0 then begin if IsWindowResponding(Wnd,100) then SendMessage( HWND_BROADCAST, RegisterWindowMessage('myAppMessage'), msg, value ) else Error('hung!!'); end; end; Es funktioniert in einem Service unter XP. Es funktioniert NICHT in einem Service unter Vista. Wnd ist da immer 0. Anscheinend funktioniert FindWindow in einem Service unter Vista nicht mehr. Gibt es eine andere Möglichkeit Nachchrichten an ein Fenster zu schicken? (damit es z.B. in den Vordergrund kommt). Danke im Voraus! |
Re: FindWindow in einem Service unter Vista
Interaktive Dienste gibt es unter Vista aus Sicherheitsgründen nicht mehr, und auch bei XP musste man das ggf. erlauben.
|
Re: FindWindow in einem Service unter Vista
Der Dienst ist nicht als Interaktiv gekennzeichnet! (funktioniert also unter XP mit ausgeschalteter Interaktivität).
|
Re: FindWindow in einem Service unter Vista
|
Re: FindWindow in einem Service unter Vista
Zitat:
|
Re: FindWindow in einem Service unter Vista
Luckie, wieso funktioniert es dann unter XP? Ist es nur Zufall dass es dort in der gleichen WS ist?
|
Re: FindWindow in einem Service unter Vista
Das kann unter XP nur mit einem interaktiven Service funktionieren.
|
Re: FindWindow in einem Service unter Vista
Hallo,
unter welchem Account läuft denn der Dienst unter XP ? Vielleicht ist bei dem benutzten Account interaktiv automatisch "freigeschaltet". Heiko |
Re: FindWindow in einem Service unter Vista
Gibt es keinen Workaround um eine Nachricht aus dem Service zu der App zu schicken? In die andere Richtung geht es ja, über den ServiceManager.
|
Re: FindWindow in einem Service unter Vista
Ich habe das über ein MemoryMapped-File und ein Event/Mutex/whatever gebaut. Ist relativ einfach und funktioniert gut, Source kann ich leider keinen posten, da nicht zuhause :)
HTH |
Re: FindWindow in einem Service unter Vista
Poste bitte den Code, wenn du wieder zu Hause bist.
|
Re: FindWindow in einem Service unter Vista
Die Lösung für Dein Problem:
Benutz einen anderen IPC Mechanismus. Mit Window Messages rumspielen in nem Service ist nicht nur relativ dämlich (weil Du auf Deine eigene Terminal Session begrenzt bist) sondern kann durchaus auch die ein oder andere Gefahr in sich bergen. Sollte Dein Service übrigens ein Window erzeugen um Window Messages zu empfangen, darf ich Dir an dieser Stelle sogar zu Deinem ersten exploitbaren Sicherheitsproblem gratulieren ;). Das Problem wieso Dein FindWindow innerhalb eines Service unter Vista nicht funktioniert, ist recht einfach. Anders als bei XP rennen Services unter Vista in einer eigenen Terminal Service Session. Da alle Fenster und Fenster Handles nur für die jeweilige Session gelten in der sie auch erstellt wurden, findet Dein Service (der in Session 0 läuft) keinerlei Fenster von Applikationen die Du als Nutzer gestartet hast (welche nämlich in Session 1 laufen). Selbst wenn du übrigens ein Fenster Handle bekommen solltest, wäre es unmöglich von Session 0 heraus eine Message an Session 1 zu schicken. Ich persönlich würde Dir zur Kommunikation Named Pipes empfehlen, da Du Dir um die Synchronisation weit weniger Gedanken machen muss als z.B. bei Memory Mapped Files. Entsprechende Beispiele findest Du hier im Board zu genüge. Solltest Du mehr über die Hintergründe der Änderung wissen möchten, empfehle ich Google mit "vista session 0 isolation" und "shatter attacks" als Suchbegriffe. |
Re: FindWindow in einem Service unter Vista
Da springe ich doch mal schnell in den Thread rein und schreibe
"ich bin wie immer in diesem Fall für TCP/IP, funktioniert immer und wird auch immer funktionieren" ...mal gucken in wie vielen anderen Threads, die das Thema "Window Messages /Services /Vista" behandeln ich noch diesen Satz schreiben werde...ich sollte mir einen Counter dafür anlegen :mrgreen: |
Re: FindWindow in einem Service unter Vista
Zitat:
|
Re: FindWindow in einem Service unter Vista
Zitat:
|
Re: FindWindow in einem Service unter Vista
Zitat:
Wer weiss wie lange Named Pipes noch funktionieren werden. Da kann Microsoft auf die Idee kommen die nicht mehr zu unterstützen. Wie könnten sie aber auf die Idee kommen TCP/IP nicht mehr zu unterstützen? |
Re: FindWindow in einem Service unter Vista
Zitat:
Bei Named Pipes hast du als Entwickler den Vorteil, dass es der Implementation überlassen bleibt, welches Transportprotokoll verwendet wird (und "Lokales RPC" dürfte schneller sein, als deine TCP/IP-Verbindung). Wie Bernhard Geyer bereits schrieb, ist eher die Praxis das Problem (Software-Firewalls). |
Re: FindWindow in einem Service unter Vista
Zitat:
|
Re: FindWindow in einem Service unter Vista
Zitat:
|
Re: FindWindow in einem Service unter Vista
Zitat:
|
Re: FindWindow in einem Service unter Vista
Zitat:
Zitat:
|
Re: FindWindow in einem Service unter Vista
Fensternachrichten (bzw. Fensterhandles) bezogen sich schon immer auf einen Desktop. Wenn der Dienst nicht auf dem gleichen/interaktiven Desktop läuft, dann hatte man schon vorher das Problem (Windows Terminal Server mit mehreren Benutzern).
|
Re: FindWindow in einem Service unter Vista
Zitat:
Es muss nicht alles immer logisch sein was in SW realisiert wurde. |
Re: FindWindow in einem Service unter Vista
Ich weiss nicodex.
Ich kenn den Zusammenhang. Wir hatten auch Dienste die über nicht sichtbare Fenster im Dienst mit anderen Applikationen über Fensternachrichten (WM_COPYDATA) kommuniziert haben. Diese Programme und Dienste waren nicht für Terminals konzipiert. Bei unseren Kunden lief alles super. ...dann kam Vista...und wir standen vor der Entscheidung, was nun? ...wir haben für die IPC TCP/IP gewählt, weil wir vermuten, daß das im Rahmen des IPC lange funktionsfähig bleiben wird. Wir haben angenommen, daß es wahrscheinlich länger funktionieren dürfte als andere IPC Verfahren, die u.U. irgendwann in einer in Zukunft liegenden Windowsversion nicht mehr läuft. Ist halt eine Entscheidung, die jeder für sich treffen muss. Keine Frage Named Pipes funktionieren wunderbar. Ich bevorzuge aber immer noch TCP/IP. |
Re: FindWindow in einem Service unter Vista
Das funkz schon nicht mehr in XP, weil dort FUS und RDP mit TS realisiert wurde.
|
Re: FindWindow in einem Service unter Vista
Zitat:
Zitat:
Zitat:
|
Re: FindWindow in einem Service unter Vista
Memory Mapped Files, RPC/LPC und Pipes sind Grundlagen von Betriebsystemen, die es schon von (fast) Anfang an gibt. Wenn es das nicht mehr gibt, möchte ich gerne sehen, was da Besseres kommt :)
Der Vorteil von Memory Mapped Files, RPC/LPC und Pipes ist u.a., dass man sie schützen kann, so dass nicht jeder Prozess darauf zugreifen kann. Bei TCP/IP muss man sich selbst etwas ausdenken. Aber zumindest funktioniert schonmal die Verbindung. |
Alle Zeitangaben in WEZ +1. Es ist jetzt 07:57 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz