TA的每日心情 | 奋斗 3 天前 |
---|
签到天数: 2393 天 [LV.Master]伴坛终老
|
标题 用VB学做“黑客”程序
\& d2 y6 j5 N6 F
. E) i* C4 z C关键字 VB,黑客
8 R' Z7 d) ~* X6 j! W
M! q7 C: M% G3 d i3 f* w, [9 }. q
1 n8 Z# u4 G+ b8 k6 ^/ Y1 O; q1 q0 p, L3 @+ L( U% K% s/ n/ h" J
用VB学做“黑客”程序
( D8 i4 F; q/ L' R9 d' ~# ]
3 Z/ m3 K0 H- g# L! k4 P4 k4 N b ( z+ W2 |. O: n0 z- d# P
5 O y1 L+ |% Z8 j# S) V
只要掌握了原理,你也能写出一个所谓的“黑客”程序。下面笔者带领大家用VB亲自编写一个远程控制程序。从而揭开它的神秘面纱。
& l; i/ S' f' l" j9 o8 p4 B% s: a% c( }( \
一、所用控件
( ^6 U ~1 R- x0 C6 `
6 X; o" y4 V) m, ^* y/ |, I 在程序中将使用Winsock控件。Winsock控件是一个ActiveX控件,使用TCP协议或UDP协2 x: K" _) O" V: c1 e
议连接到远程计算机上并与之交换数据。和定时器控件一样,Winsock控件在运行时是不可见的。Winsock的工作原理是:客户端向服务器端发出连接请求,服务器端则不停地监听客户端的请求,当两者的协议沟通时,客户端和服务器端之间就建立了连接,这时客户端和服务器端就可以实现双向数据传输。实际编程中,必须分别建立一个服务器端应用程序和一个客户端应用程序,两个应用程序中分别有自己的Winsock控件。首先设置Winsock控件使用的协议,这里我们使用TCP协议。现在,让我们开始用VB建立两个程序,一个是客户端程序myclient,另一个是服务器端程序myserver。) x7 g7 _# F% T# h% i- P ?
3 i3 v" X- N. R- z6 N
二、编写客户端程序
' {# M/ N% k; ]" k2 g5 |' M7 k/ \9 L7 s/ B, |
首先来建客户端程序myclient。在myclient程序中建立一个窗体,加载Winsock控件,称为tcpclient,表示使用的是TCP协议,再加入两个文本框(text1和text2),用来输入服务器的IP地址和端口号,然后建立一个按钮(cd1),用来建立连接,按下之后就可以对连接进行初始化了,代码如下:
$ O8 z9 n4 R% Z1 P
m8 C' V6 Y6 N& U6 X private sub cd1_click()0 a2 h' A! w0 f3 a, J2 \1 S" S( \
7 M/ I* P0 G) c H3 P+ N! u
tcpclient.romotehost=text1.text- F P# m/ b; X8 @& Z8 r
9 Q \; f! D: F0 H2 i
tcpclient.romoteport=val(text2.text)'端口号,缺省为1001. B/ H- t$ B ^: Z
. B+ N% }# k! z8 F" X$ W
tcpclient.connect '调用connect方法,与指定IP地址的计算机进行连接" R9 ]* t( j) O! z
* H ?/ b1 T' h/ J" e9 Z5 C, w
cd1.enabled=false# \ m1 z" @* r& ?% I, k
5 r" D/ o9 z. g
end sub1 V8 @8 q- ?, Y; |8 n
$ X+ A" S C' E5 v% o
连接之后就是如何处理所收到的数据的问题了。客户端和服务器端建立连接后,如果有任何一端接收到新的数据,就会触发该端winsock控件的dataarrival事件,在响应这个事件时,可以使用getdata方法获得发送来的数据。比如可以在tcpclient的dataarrival事件中编写代码如下:
( d) z# ^2 _1 q/ @1 d
' ^* E6 _. V e" L private sub tcpclient_dataarrival(byval bytestotal as long)7 I' P- \# T/ e, `8 S
. Z% w" l5 W( [2 }5 o$ V; ~) f' ^
dim x as string2 a, |' K" p, u9 G: t1 X
2 a% n" D: K7 p% z8 r
tcpclient.getdata x '使用getdata获得发送来的数据
+ Y9 E: ^6 o5 g' e0 N$ @& j
6 P W! \% h/ q: x .......
# P& A$ a% T- E( T& t# k( ]8 z2 c9 \. c# p4 F
End sub) }* j/ ?: Z* c7 Z, O
( b" N! G+ b& T. ?: n- j 后面的省略部分表示对接收到的数据进行的具体处理,读者可以根据实际情况编写。
5 P9 B4 q. c* T! k8 Y n8 g8 D1 C& l. M. u
三、编写服务器端程序
& c/ D2 m4 D+ r5 t1 t% F2 J1 u! A. R% ~7 N E" ]/ D
先建立一个窗体,加载Winsock控件,名称为tcpserver。另外在窗体上加入一个文本框text1用来显示客户机的IP地址和客户机发送过来的数据信息。
! E4 I0 m3 e: e8 H& \8 ]: L7 ? O% N8 z1 Z/ x6 B4 M
当客户端程序运行时,在客户端程序按下连接按钮后,客户端向服务器端程序请求连接,这时服务器端的connectionrequest事件被触发,所以服务器端程序要解决连接问题,可以使用connectionrequest事件完成此功能。代码如下:
4 f7 C7 G8 R2 F. ?/ ~: d: i$ W M# `/ Z
'在窗体的load事件中对tcpserver控件进行初始化9 h- ]4 T' a( Z# o1 e+ R- d) {( {1 G
! \5 j( L: V/ r- O: ], r1 ` private sub form_load()
V0 {1 |8 H8 {4 m: t* }/ M& ]- X/ T. F$ X) ~* j/ n
tcpserver.localport=1001: H1 H( t7 S) K& P" j0 ^
( B5 X* x! y) O0 H @2 w tcpserver.listen '把服务器置于监听检测状态 d) |# R/ T5 E
! @2 L( Q s$ L' B+ ~ C
end sub
4 P: }) c0 `9 _5 T( p* y8 c
1 R: P2 R2 }* y( s5 F' j '服务器端接收到客户端的连接请求,首先检查当前状态是否处于连接关闭状态
* X1 X3 ^" a, ? z
, F0 q: [- N! l7 I s Private sub tcpclient_connectionrequest(Byval requestID as long)
% h3 U' I0 t g R0 G3 H
7 @: `$ e, a4 g If tcpserver.state<>sckclosed then '检查控件的state属性是否为关闭
' N$ _- e! K" m+ O8 F/ \) k( n
0 U6 z" J/ P, l4 W& u: u/ z Tcpserver.close '" N. i* g. v8 t2 w# a# A
1 |! F) `/ F7 R; k( _' Q' H Tcpserver.accept requestID '
# B! M8 `+ b, N" {
( l# i8 K. i$ W y End if
4 L/ k. m/ ]5 b1 b: T3 X/ [- N2 ?
, T( u7 \5 f. d2 F- s End sub9 C9 N* x( _4 G# n3 O
0 s% P' I' V* }2 m1 h* w6 j% k" x( Y
现在我们在服务器端程序tcpserver的dataarrival事件中添加以下代码,以便让服务器端程序可以接收客户机端的指令,并运行相应的程序。9 G/ C8 Z7 k' x+ h( X% E
8 C) q, i' P4 j
四、测试远程控制程序+ j* Q8 \0 Q: z: l" F# a3 ?$ U: d
3 h5 P; S" w# `) X% N0 x, ]
现在,你就可以将这两个程序分别运行于两台使用TCP/IP协议联网的机器了。在客户机端你按下连接按钮,再输入“c: mmand.com”,可以看到在服务器端立刻打开一个DOS窗口,设想一下,如果它运行一些破坏性的命令会发生什么事情?这就是一个最基本的远程控制程序。当然,真正的黑客程序要复杂得多,但基本原理是相同的。现在你该恍然大悟了吧?
: N1 p* M4 o- c; Q |
|