• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            cyt
            首先,要控制windows services,是比較容易的事情,一堆現成的例子。
            SYNtService 就是一個很好的例子。
            要控制一個窗口退出是十分容易的事情,PostMessage就可以解決問題。
            要控制console退出,也有很多現成的方法。比較通用的方法:
            1、TerminateProcess
               最原始、最暴力的強制console退出的方法。console進程毫無還手之力就over了。但我希望console在推出之前至少能處理一下“后事”。

            2、signal / raise
               原來windows也有signal,不過kill換成了raise。但是相對Unix系列的signal功能就差很遠了。而且有一個麻煩的地方就是raise只能對本console生效,而不能對指定的process。
               可以在signal里面指定一個call back函數,在收到SIGINT/SIGTERM之類的時候,處理一下事情,然后通知各個線程結束。
               既然不能raise其他進程,是否這個功能就不能用了呢?其實可以考慮一下CreateRemoteThread,然后在別人的進程里面raise……

            3、SetConsoleCtrlHandler / GenerateConsoleCtrlEvent
                這個是console專門用來處理Ctrl-C/Ctrl-Break/以及windows關機事件等的處理方法。比signal更強大。而且說明中寫了,可以對其他的進程進行處理(還可以對進程組處理)。用網上的話說就是:很女子,很弓雖!
                但是要注意,如果要對其創建的子進程進行處理的時候,創建子進程必須要使用CREATE_NEW_PROCESS_GROUP標志。另外一點,文檔寫的比較隱晦的就是,進程必須要有console窗口。否則,調用GenerateConsoleCtrlEvent會返回6,說ERROR_INVALID_HANDLE。
                問題來了,Service本身是沒有console窗口的,Service建立的子進程就必須要自帶窗口了。但是一般為了美觀,Service啟動的進程都不想帶有窗口。那就變成了子進程沒有console窗口,GenerateConsoleCtrlEvent失效了。
                在網上查了很多資料(怎么沒看到很黃很暴力呢???),其中在 Louis K. Thomas <louiNØSP@Msth@hotmÑOSP@Mail.coNÕSP@Mm> 的 SendSignal 提到一種做法,就是先獲得kernel32!CtrlRoutine的入口,然后通過CreateRemoteThread的方法,讓遠程的console來執行kernel32!CtrlRoutine。但這種方法有個問題,在獲得kernel32!CtrlRoutine的時候,也是使用GenerateConsoleCtrlEvent來獲得。但是Service自己本身沒有console窗口,一調用GenerateConsoleCtrlEvent也是出錯。
            而另一篇 google討論組 文章,里面提到原來可以先AllocConsole、然后GenerateConsoleCtrlEvent、然后FreeConsole……于是解決方案就變成:
            Service里面:
              先AllocConsole
              然后利用GenerateConsoleCtrlEvent獲得kernel32!CtrlRoutine
              然后FreeConsole
              當需要結束進程的時候,就調用CreateRemoteThread,把kernel32!CtrlRoutine的代碼注入到子process中執行
              這樣大家都看不到console窗口(service里面AllocConsole很快,看不到窗口出來,甚至懷疑根本就有沒有窗口出來),同時又能通知子進程優雅地退出。

            存在問題:如果我的機器作為服務器啟動,即沒有進入登錄狀態,不知道這樣啟動的Service會不會有問題呢??暫時還沒有時間測試。


               
               

            posted on 2008-01-08 16:07 cyt 閱讀(4589) 評論(4)  編輯 收藏 引用 所屬分類: Work
            Comments
            • # re: 如何在windows service里面控制console程序退出
              eXile
              Posted @ 2008-01-09 11:45
              沒大明白,有代碼就好了。。。  回復  更多評論   
            • # re: 如何在windows service里面控制console程序退出
              夢醒驚魂
              Posted @ 2008-03-18 02:36
              呵呵,不錯,很黃很爆力,正找這個問題,難怪我都不成功,原來GenerateConsoleCtrlEvent必須要有console窗口。真是太感謝了,交個朋友好嘛?

              QQ:522986976  回復  更多評論   
            • # re: 如何在windows service里面控制console程序退出
              cyt
              Posted @ 2008-05-05 17:55
              樂意交這個朋友

              后來我測試過,CreateRemoteThread這種方法其實也是可以。這種方法按作者的說法有一個問題是:如果新的進程帶有窗口,就會失敗。但是在我的情況下不會有窗口。所以我最后選擇這種方法了。連dos窗口閃一下都沒有了,完美解決。  回復  更多評論   
            • # re: 如何在windows service里面控制console程序退出
              DDGG
              Posted @ 2008-06-10 16:19
              cyt能給個用CreateRemoteThread實現的例子么?謝謝啊!  回復  更多評論   
             
            欧美精品一本久久男人的天堂| 精品无码久久久久久尤物| 亚洲精品无码成人片久久| 欧美va久久久噜噜噜久久| 久久久久精品国产亚洲AV无码| 人妻精品久久无码专区精东影业| 日韩精品久久久久久| 久久国产精品免费一区二区三区| 五月丁香综合激情六月久久| 天天久久狠狠色综合| 91久久成人免费| 亚洲国产精品综合久久一线| 久久亚洲国产最新网站| 亚洲精品国产第一综合99久久| www.久久99| 91精品国产综合久久香蕉| 成人国内精品久久久久影院VR| 久久久精品人妻一区二区三区蜜桃| 久久综合中文字幕| 久久精品这里只有精99品| 午夜精品久久影院蜜桃| 亚洲中文久久精品无码ww16| 精品久久久久久国产潘金莲| 99国内精品久久久久久久| 中文字幕亚洲综合久久2| 亚洲午夜无码AV毛片久久| 人妻丰满AV无码久久不卡| 国产午夜久久影院| 久久国产影院| 国产69精品久久久久观看软件| 国产综合免费精品久久久| 国产亚洲精品自在久久| 久久精品无码专区免费| 亚洲精品tv久久久久久久久| 91久久香蕉国产熟女线看| 久久久久亚洲av成人网人人软件 | 久久成人国产精品二三区| 国内精品久久久久影院网站 | 久久综合九色综合97_久久久| 99久久综合狠狠综合久久止| 久久久久人妻一区精品|