|
楼主 |
发表于 2008-8-30 15:44:07
|
显示全部楼层
20.RUNDLL32.EXE 是什么程序
) `* V9 Z9 z3 o B9 y) o2 f
( o1 T/ K, @5 V3 H) t Rundll32.exe是什么?顾名思意,“执行32位的DLL文件”。它的作用是执行DLL文件中的内部函数,这样在进程当中,只会有Rundll32.exe,而不会有DLL后门的进程,这样,就实现了进程上的隐藏。如果看到系统中有多个Rundll32.exe,不必惊慌,这证明用Rundll32.exe启动了多少个的DLL文件。当然,这些Rundll32.exe执行的DLL文件是什么,我们都可以从系统自动加载的地方找到。! j0 d& d: B1 E' w T5 f
" \1 t9 k: F" e. b! k
现在,我来介绍一下Rundll32.exe这个文件,意思上边已经说过,功能就是以命令行的方式调用动态链接程序库。系统中还有一个Rundll.exe文件,他的意思是“执行16位的DLL文件”,这里要注意一下。在来看看Rundll32.exe使用的函数原型:
5 f: t X' V9 \7 y1 s! ^ Void CALLBACK FunctionName (
) T6 O/ G% r7 B* h6 {$ x HWND hwnd,
# b7 v& ^) ~+ Q! L$ p5 _8 z HINSTANCE hinst,
# O4 @# T* g0 ^" }5 n LPTSTR lpCmdLine,
- B" g0 Y$ M0 ?; C Int nCmdShow
' J8 m3 H% V! A0 r7 W );* O* C/ V5 H; `2 I( G
$ M4 G3 r) {1 N; m O 其命令行下的使用方法为:Rundll32.exe DLLname,Functionname [Arguments]; ]: j+ z+ T l8 E
DLLname为需要执行的DLL文件名;Functionname为前边需要执行的DLL文件的具体引出函数;[Arguments]为引出函数的具体参数。+ V2 a1 D: d s2 R L) w, g! e
略谈Rundll32.exe的作用 (我是菜鸟) - j; U/ y b3 S+ K5 ~
/ C: s2 M& F8 i6 m, v8 l
0 |, j0 P, A- t" u! P
$ V& i+ t. N: L8 ^
常用Windows9x的朋友一定对Rundll32.exe和Rundll.exe这两个档案不会陌生吧,不过,由於这两个程式的功能原先只限於在微软内部使用,因而真正知道如何使用它们的朋友想必不多。那么好,如果你还不清楚的话,那么就让我来告诉你吧。 ; |, z) O) [% k7 r: F
首先,请你做个小实验(请事先保存好你正在执行的程式的结果,否则...):点击“开始-程式-Ms-Dos方式”,进入Dos视窗,然後键入rundll32.exe user.exe,restartwindows,再按下回车键,这时你将看到,机器被重启了!怎么样,是不是很有趣?
- u: ?3 M! [8 Y1 L/ H6 |7 i- T& I 当然,Rundll的功能绝不仅仅是重启你的机器。其实,Rundll者,顾名思义,执行Dll也,它的功能就是以命令列的方式呼叫Windows的动态链结库,Rundll32.exe与Rundll.exe的区别就在於前者是呼叫32位的链结库,而後者是运用於16位的链结库,它们的命令格式是:
+ M+ ^" \# k) D$ l) f9 a$ ?) b0 a# L% n* |
RUNDLL.EXE ,,
% h L+ N, i1 r& r 这里要注意三点:1.Dll档案名中不能含有空格,比如该档案位於c:\ProgramFiles\目录,你要把这个路径改成c:\Progra~1\;2.Dll档案名与Dll入口点间的逗号不能少,否则程式将出错并且不会给出任何资讯!3.这是最重要的一点:Rundll不能用来呼叫含返回值参数的Dll,例如Win32API中的GetUserName(),GetTextFace()等。在Visual Basic中,提供了一条执行外部程式的指令Shell,格式为: 3 n: E' c" j' R; g) q
Shell “命令列”
* ]' C$ s6 i: o% c6 y 如果能配合Rundll32.exe用好Shell指令,会使您的VB程式拥有用其他方法难以甚至无法实现的效果:仍以重启为例,传统的方法需要你在VB工程中先建立一个模组,然後写入WinAPI的声明,最後才能在程式中呼叫。而现在只需一句: 1 y. h1 o* C1 g* L1 c! O
$ [5 K' H& o& g! P9 g8 Q3 c% h Shell “rundll32.exe user.exe,restartwindows”就搞定了!是不是方便多了?
! n7 X1 N3 f) f 实际上,Rundll32.exe在呼叫各种Windows控制面板和系统选项方面有著独特的优势。下面,我就将本人在因特网上收集的有关Rundll的指令列举如下(很有用的,能省去你很多呼叫Windows API的时间!!),供大家在程式设计中引用:
$ a9 N8 l: B y* D5 _0 ^$ H 命令列: rundll32.exe shell32.dll,Control_RunDLL 3 G5 t+ ^/ s; |6 U V4 |
功能: 显示控制面板
& \/ y0 v7 ^ t$ u, b- o: }" m 命令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,1 : d* l q% U8 ^( o& _3 ~( N
功能: 显示“控制面板-辅助选项-键盘”选项视窗 # b: O R0 C5 r! B
命令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,2
/ y( r ]( |1 z. | 功能: 显示“控制面板-辅助选项-声音”选项视窗
1 Z6 H0 O* o5 a* r' }: \6 Q 命令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,3
9 u \# p! X, z; U+ G' N- S/ M& e 功能: 显示“控制面板-辅助选项-显示”选项视窗
1 ?+ F* G4 B' R 命令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,4 & W6 L$ H( I* m/ e0 d1 Z
功能: 显示“控制面板-辅助选项-滑鼠”选项视窗 * z# f3 X G* H$ ~5 i
命令列: rundll32.exe shell32.dll,Control_RunDLL access.cpl,,5
) ?# X! m5 p0 H3 F 功能: 显示“控制面板-辅助选项-传统”选项视窗 % D& s: Y; ^' u# c! Y, ]
命令列: rundll32.exe shell32.dll,Control_RunDLL sysdm.cpl @1
+ Y* b: _1 A8 k5 ~- w) Z8 c- t 功能: 执行“控制面板-添加新硬体”向导。 & e% ~% f* D- ^# m# j
命令列: rundll32.exe shell32.dll,SHHelpShortcuts_RunDLL AddPrinter
6 d6 ~0 j3 Y0 a9 Y4 s 功能: 执行“控制面板-添加新印表机”向导。
% {5 J; _+ O! e1 D9 l. I; u5 } 命令列: rundll32.exe shell32.dll,Control_RunDLL appwiz.cpl,,1
' d8 M: |8 c1 S 功能: 显示 “控制面板-添加/删除程式-安装/卸载” 面板。
+ ~! P3 F. x6 R; V( g g 命令列: rundll32.exe shell32.dll,Control_RunDLL appwiz.cpl,,2
/ n3 c+ c) I! w; m1 v 功能: 显示 “控制面板-添加/删除程式-安装Windows” 面板。 ) c% z, W: v, l# U6 H( s
命令列: rundll32.exe shell32.dll,Control_RunDLL appwiz.cpl,,3
* [, I' i" n2 d: b0 o: E 功能: 显示 “控制面板-添加/删除程式-启动盘” 面板。
" E5 F9 k# J1 `, F6 C1 W; w* r 命令列: rundll32.exe syncui.dll,Briefcase_Create 3 \* k% R9 j! U0 i" O
功能: 在桌面上建立一个新的“我的公文包”。 + T. z- D: u% x; |
命令列: rundll32.exe diskcopy.dll,DiskCopyRunDll 8 G2 }7 C; @7 \
功能: 显示复制软碟视窗 * P) `3 @8 T6 D. X0 b* O8 D
命令列: rundll32.exe apwiz.cpl,NewLinkHere %1 8 k5 g5 x' D5 O* v! j. O
功能: 显示“建立快捷方式”的对话框,所建立的快捷方式的位置由%1参数决定。
- w! E9 ~7 C) m" I1 @" U 命令列: rundll32.exe shell32.dll,Control_RunDLL timedate.cpl,,0
/ X# ^9 b$ i: T! U: H 功能: 显示“日期与时间”选项视窗。 ! V# c1 ?; \6 t6 U0 L4 |3 D+ p2 C* D
命令列: rundll32.exe shell32.dll,Control_RunDLL timedate.cpl,,1 ) J* y7 [4 Z- i3 n4 p
功能: 显示“时区”选项视窗。
7 z6 Q7 h/ b9 w8 W 命令列: rundll32.exe rnaui.dll,RnaDial [某个拨号连接的名称]
6 _# y" n0 O/ Y/ B# J 功能: 显示某个拨号连接的拨号视窗。如果已经拨号连接,则显示目前的连接状态的视窗。
: J& l" _9 S' x. K* ]* [$ s 命令列: rundll32.exe rnaui.dll,RnaWizard 8 M2 o- B6 R% |$ } \6 N: m
功能: 显示“新建拨号连接”向导的视窗。
# L7 B9 ~6 P5 k9 q, c) _+ z 命令列: rundll32.exe shell32.dll,Control_RunDLL desk.cpl,,0 % g( s; H2 B, P! j/ S2 \
功能: 显示“显示属性-背景”选项视窗。 0 N# e# [% b0 G& G2 ~, k b+ l
命令列: rundll32.exe shell32.dll,Control_RunDLL desk.cpl,,1 / D, F, d% l( J* r) z
功能: 显示“显示属性-萤屏保护”选项视窗。
( @: Z5 K/ K) L G9 x% g7 @ 命令列: rundll32.exe shell32.dll,Control_RunDLL desk.cpl,,2
4 y1 ~- t8 I! y- @1 @ 功能: 显示“显示属性-外观”选项视窗。
+ E. p5 E: t9 E1 {' n) } 命令列: rundll32.exe shell32.dll,Control_RunDLL desk.cpl,,3 2 \% r1 ^8 c6 x, h4 r7 C
功能: 显示显示“显示属性-属性”选项视窗。
$ X* |1 j' O+ }2 v$ V 命令列: rundll32.exe shell32.dll,SHHelpShortcuts_RunDLL FontsFolder 6 w1 T0 Z9 b! q
功能: 显示Windows的“字体”档案夹。 , N9 Q- S( ?' Q; R2 m; J. q. K( D
命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @3
' l" l7 D* y7 h! U4 ?2 J* K 功能: 同样是显示Windows的“字体”档案夹。 ' W/ r" c3 o6 v* c
命令列: rundll32.exe shell32.dll,SHformatDrive * G9 h& i1 i/ c
功能: 显示格式化软碟对话框。 " `1 r% P8 A& m3 m
命令列: rundll32.exe shell32.dll,Control_RunDLL joy.cpl,,0
. v: _3 B5 {0 F( b9 Y 功能: 显示“控制面板-游戏控制器-一般”选项视窗。 # u t% ?; E) H
命令列: rundll32.exe shell32.dll,Control_RunDLL joy.cpl,,1 3 ~. c1 N8 W/ p5 M. n: g& g
功能: 显示“控制面板-游戏控制器-进阶”选项视窗。 1 U7 i( c# X% g; j. q; J- z' l
命令列: rundll32.exe mshtml.dll,PrintHTML (HTML文档)
- d6 L* I8 G: @# o2 |; i 功能: 列印HTML文档。
. k5 S( A+ |. ]( m5 M 命令列: rundll32.exe shell32.dll,Control_RunDLL mlcfg32.cpl % O0 m' Q% c8 p, @3 \3 F f4 N
功能: 显示Microsoft Exchange一般选项视窗。
# a: F: O0 l, Q5 _! X 命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @0 . n4 O9 O0 f7 C9 x! A5 I
功能: 显示“控制面板-滑鼠” 选项 。
1 t* D2 h) h5 k' P1 @ 命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @1
+ u9 i# J$ r1 e, d4 t 功能: 显示 “控制面板-键盘属性-速度”选项视窗。 7 B. u6 i8 e; h% p- h
命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @1,,1 / ~1 x+ ^& R B3 i
功能: 显示 “控制面板-键盘属性-语言”选项视窗。
) d( S& J2 j/ W' N0 E; M$ t) H 命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @2
9 h8 n4 F/ o1 O/ F) _ 功能: 显示Windows“印表机”档案夹。 1 I8 \3 ~$ W8 [0 S4 y* q
命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @3 - N9 y/ `; N" |
功能: 显示Windows“字体”档案夹。 . t+ }* b7 w L0 G: j) P4 U* J
命令列: rundll32.exe shell32.dll,Control_RunDLL main.cpl @4 + k9 l, s& h6 C0 B/ h: f D6 B
功能: 显示“控制面板-输入法属性-输入法”选项视窗。 % _' n; v0 f0 I# l
命令列: rundll32.exe shell32.dll,Control_RunDLL modem.cpl,,add
6 R: G3 ~. [ p7 I) }" N! ? 功能: 执行“添加新调制解调器”向导。 0 d( x5 v" ?5 D/ ^( r: }. R
命令列: rundll32.exe shell32.dll,Control_RunDLL mmsys.cpl,,0
4 N/ _2 Q- M5 s" l6 v. q3 O/ g* f. j8 b( z 功能: 显示“控制面板-多媒体属性-音频”属性页。 ( k# ~& ^4 r% v- j' D2 x3 ^
命令列: rundll32.exe shell32.dll,Control_RunDLL mmsys.cpl,,1
; }) c& c: |& }( J! t4 w( @ 功能: 显示“控制面板-多媒体属性-视频”属性页。
0 M. O2 S) Z4 O0 }* E& v6 m 命令列: rundll32.exe shell32.dll,Control_RunDLL mmsys.cpl,,2
" u) s8 F9 Y+ |9 m7 C, O( v8 I 功能: 显示“控制面板-多媒体属性-MIDI”属性页。 3 y, G, c: }2 I
命令列: rundll32.exe shell32.dll,Control_RunDLL mmsys.cpl,,3
0 ]) t1 }+ F4 I6 ?/ I, [2 M 功能: 显示“控制面板-多媒体属性-CD音乐”属性页。
6 M3 l' @( f" H 命令列: rundll32.exe shell32.dll,Control_RunDLL mmsys.cpl,,4
2 U" {8 L5 r, E% x+ _. R6 E 功能: 显示“控制面板-多媒体属性-设备”属性页。
% m- B" }# i+ w$ c' Q7 W 命令列: rundll32.exe shell32.dll,Control_RunDLL mmsys.cpl @1 " N5 z# P( j. a* g0 Z7 L
功能: 显示“控制面板-声音”选项视窗。
8 x4 ]8 H' g: M) S$ L4 I2 d 命令列: rundll32.exe shell32.dll,Control_RunDLL netcpl.cpl # [9 d3 |( |; K! E3 G; D4 x4 H
功能: 显示“控制面板-网路”选项视窗。 4 H% o0 Y& S- p
命令列: rundll32.exe shell32.dll,Control_RunDLL odbccp32.cpl
1 W1 e3 f2 @+ P* b8 c 功能: 显示ODBC32资料管理选项视窗。 + R/ j3 |/ c0 g1 z: X! f
命令列: rundll32.exe shell32.dll,OpenAs_RunDLL {drive:\path\filename}
. U6 o/ Q Z: i6 u: a9 \
' ?( O1 i1 E) x$ D. ~- A3 j6 s/ j% Q 功能: 显示指定档案(drive:\path\filename)的“打开方式”对话框。
& ^6 x t) K5 V! m0 O 命令列: rundll32.exe shell32.dll,Control_RunDLL password.cpl
9 y* D) q f4 ?6 I4 K/ L# ` 功能: 显示“控制面板-密码”选项视窗。 / G$ J$ Q }; B6 f
命令列: rundll32.exe shell32.dll,Control_RunDLL powercfg.cpl % e9 \& p [, a6 U8 J
功能: 显示“控制面板-电源管理属性”选项视窗。
( c& @& Z* i/ ] ^ 命令列: rundll32.exe shell32.dll,SHHelpShortcuts_RunDLL PrintersFolder
' A6 ]2 \6 Y# d 功能: 显示Windows“印表机”档案夹。(同rundll32.exe shell32.dll,Control_RunDLL main.cpl @2)
! x) g/ \% F7 V$ }* L6 { 命令列: rundll32.exe shell32.dll,Control_RunDLL intl.cpl,,0
! M g0 L: S' N& s8 T. \ 功能: 显示“控制面板-区域设置属性-区域设置”选项视窗。 7 Q( \0 V( ]5 P, B
命令列: rundll32.exe shell32.dll,Control_RunDLL intl.cpl,,1
/ x4 u. s# j6 T2 c- E% } 功能: 显示“控制面板-区域设置属性-数字”选项视窗。
* K8 o8 t8 P. N; A/ h: b 命令列: rundll32.exe shell32.dll,Control_RunDLL intl.cpl,,2
& K4 V% ~4 l! n 功能: 显示“控制面板-区域设置属性-货币”选项视窗。
8 D) k8 U5 Q! i- S 命令列: rundll32.exe shell32.dll,Control_RunDLL intl.cpl,,3 7 U3 K O* d! h3 H
功能: 显示“控制面板-区域设置属性-时间”选项视窗。
- f, D2 I' p# ?9 h% S# a3 o5 r! e 命令列: rundll32.exe shell32.dll,Control_RunDLL intl.cpl,,4
3 g d+ E1 d# n7 e- `- L 功能: 显示“控制面板-区域设置属性-日期”选项视窗。 9 z; S) Q* y$ ? l: A
命令列: rundll32.exe desk.cpl,InstallScreenSaver [萤屏保护档案名]
! l# |0 E# }, K 功能: 将指定的萤屏保护档案设置为Windows的屏保,并显示萤屏保护属性视窗。
3 c8 d8 \, B8 c2 d4 D- y# \' I 命令列: rundll32.exe shell32.dll,Control_RunDLL sysdm.cpl,,0 ( t; ] _7 A, X- u0 j3 h; X* H; x {
功能: 显示“控制面板-系统属性-传统”属性视窗。 9 C/ m$ Z4 y; h% [' `. l5 o% y+ F! K) c
命令列: rundll32.exe shell32.dll,Control_RunDLL sysdm.cpl,,1 3 k3 f( p- [) ]" p& ?
功能: 显示“控制面板-系统属性-设备管理器”属性视窗。
/ r0 t9 j+ W' d& v! E 命令列: rundll32.exe shell32.dll,Control_RunDLL sysdm.cpl,,2
% X# z! n' F7 \2 B: ?& m 功能: 显示“控制面板-系统属性-硬体配置档案”属性视窗。 2 s2 Q2 U# | j6 t. p/ C7 g
命令列: rundll32.exe shell32.dll,Control_RunDLL sysdm.cpl,,3 " L3 P9 {7 _* V( I2 S( f
功能: 显示“控制面板-系统属性-性能”属性视窗。
9 U H* c% C+ K e4 e 命令列: rundll32.exe user.exe,restartwindows
6 e3 O; @5 Y7 U& L9 M% {& I 功能: 强行关闭所有程式并重启机器。
. N$ ^! s, K9 L* i& e/ a! }0 J. J 命令列: rundll32.exe user.exe,exitwindows 5 }' I! g. C4 F- d" {$ a3 b7 G
功能: 强行关闭所有程式并关机。
" x/ v5 K, ]& U5 s 命令列: rundll32.exe shell32.dll,Control_RunDLL telephon.cpl
6 ?& P& ?0 @ {* M8 ^ 功能: 显示“拨号属性”选项视窗 / v( y+ j3 @1 [# Y" ~2 n6 \8 ] T
命令列: rundll32.exe shell32.dll,Control_RunDLL themes.cpl ; x2 A& l( l1 v* Y1 {
功能: 显示“桌面主旨”选项面板 ! ~# ]6 n4 o8 }- s0 \, Q
当然,不止是VisualBasic,象Delphi.VisualC++等其他程式设计语言也可以通过呼叫外部命令的方法来使用Rundll的这些功能,具体方法这里就不再详细叙述了。灵活的使用Rundll,一定会使你的程式设计轻轻松松,达到事半功倍的效果! |
|