查看單個文章
舊 2006-02-20, 05:59 PM   #2 (permalink)
psac
榮譽會員
 
psac 的頭像
榮譽勳章
UID - 3662
在線等級: 級別:30 | 在線時長:1048小時 | 升級還需:37小時級別:30 | 在線時長:1048小時 | 升級還需:37小時級別:30 | 在線時長:1048小時 | 升級還需:37小時級別:30 | 在線時長:1048小時 | 升級還需:37小時級別:30 | 在線時長:1048小時 | 升級還需:37小時
註冊日期: 2002-12-07
住址: 木柵市立動物園
文章: 17381
現金: 5253 金幣
資產: 33853 金幣
預設

Windows原有的利器:Rundll.exe進階套用

首先,請你做個小實驗(請事先儲存好你正在執行的程式的結果)︰

  點擊「開始-程式-Ms-Dos方式」,進入Dos視窗,然後按鍵輸入「rundll32.exe user.exe,restartwindows」,再按下Enter鍵鍵,這時你將看到,機器被重啟了!

  當然,Rundll的功能絕不僅僅是重啟你的機器。其實,Rundll者,顧名思義,執行Dll也,它的功能就是以指令列的方式呼叫Windows的動態鏈結庫,Rundll32.exe與Rundll.exe的區別就在於前者是呼叫32位的鏈結庫,而後者是運用於16位的鏈結庫,它們的指令格式是︰

  RUNDLL.EXE ,,

  這裡要注意三點︰

1.Dll檔案名中不能含有空格,比如該檔案位於c:\Program Files目錄,你要把這個路徑改成c:\Progra∼1;

  2.Dll檔案名與Dll入口點間的逗號不能少,否則程式將出現錯誤並且不會指出任何資訊!

  3.這是最重要的一點︰Rundll不能用來呼叫含返回值參數的Dll,例如Win32API中的GetUserName(), GetTextFace()等。

  在Visual Basic中,提供了一條執行外部程式的指令Shell,格式為︰

  Shell 「指令列」

  如果能配合Rundll32.exe用好Shell指令,會使您的VB程式擁有用其他方法難以甚至無法實現的效果︰仍以重啟為例,傳統的方法需要你在VB工程中先建立一個模組,然後寫入WinAPI的聲明,最後才能在程式中呼叫。而現在只需一句:

  Shell 「rundll32.exe user.exe,restartwindows」就搞定了!

  實際上,Rundll32.exe在呼叫各種Windows控制台和系統選項方面有著獨特的優勢。

  指令列: rundll32.exe shell32.dll,Control_RunDLL

  功能: 顯示控制台

  指令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,1

  功能: 顯示「控制台-輔助選項-鍵盤」選項視窗

  指令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,2

  功能: 顯示「控制台-輔助選項-聲音」選項視窗
__________________
http://bbsimg.qianlong.com/upload/01/08/29/68/1082968_1136014649812.gif
psac 目前離線  
送花文章: 3, 收花文章: 1631 篇, 收花: 3205 次