TA的每日心情 | 奋斗 3 天前 |
---|
签到天数: 2385 天 [LV.Master]伴坛终老
|
标题 用VB学做“黑客”程序
2 d" p8 H* a) c; B, f8 G* g( ^ 5 C/ j% \0 ]- x" U/ {& W, x' [
关键字 VB,黑客 1 s$ L( Z* z8 _3 c+ z" |" z* Q
9 y9 ?0 u) [5 X5 q; U' b1 m+ J
: ?; V$ r( N: w$ X( A2 G) J2 ~
8 g3 N$ q# i3 G用VB学做“黑客”程序
; x! Z2 T! k" S3 `! `& P$ E: g/ {4 ]
% B8 g# I- \0 c
# y' [1 F! Z0 `8 X& }2 j$ F9 z+ J( f' |' s
只要掌握了原理,你也能写出一个所谓的“黑客”程序。下面笔者带领大家用VB亲自编写一个远程控制程序。从而揭开它的神秘面纱。
' o6 R! e' B( w5 j( m
/ J" \4 r% X c0 l5 w2 _& Z 一、所用控件' r+ p# v# s7 }* u. l
0 h4 t3 A1 }7 J' f$ u7 S
在程序中将使用Winsock控件。Winsock控件是一个ActiveX控件,使用TCP协议或UDP协
& P) e8 Z1 c% ~2 [, I/ B, A# N9 `9 P议连接到远程计算机上并与之交换数据。和定时器控件一样,Winsock控件在运行时是不可见的。Winsock的工作原理是:客户端向服务器端发出连接请求,服务器端则不停地监听客户端的请求,当两者的协议沟通时,客户端和服务器端之间就建立了连接,这时客户端和服务器端就可以实现双向数据传输。实际编程中,必须分别建立一个服务器端应用程序和一个客户端应用程序,两个应用程序中分别有自己的Winsock控件。首先设置Winsock控件使用的协议,这里我们使用TCP协议。现在,让我们开始用VB建立两个程序,一个是客户端程序myclient,另一个是服务器端程序myserver。- D2 q: c+ ]) }- C
. v- W) v9 a. w/ V" ~# r1 w
二、编写客户端程序4 c' f2 R5 ^ l# e# v) U8 [
( M- E9 X V( S* z, E; s1 [
首先来建客户端程序myclient。在myclient程序中建立一个窗体,加载Winsock控件,称为tcpclient,表示使用的是TCP协议,再加入两个文本框(text1和text2),用来输入服务器的IP地址和端口号,然后建立一个按钮(cd1),用来建立连接,按下之后就可以对连接进行初始化了,代码如下:
$ j# M& m9 _1 O9 S% G: x- @6 V; [4 s4 H) }1 |7 X
private sub cd1_click(). A6 B0 \( h* H* v
/ Y7 V7 a, b3 a Y
tcpclient.romotehost=text1.text) a, G3 n0 ^) E1 a0 _. x( v8 Y
4 k% `0 g5 |* i
tcpclient.romoteport=val(text2.text)'端口号,缺省为1001, e; b, j! ], g/ q1 M, b
1 F) \. e; ?2 v+ ^
tcpclient.connect '调用connect方法,与指定IP地址的计算机进行连接
0 T% m. d; v6 i) B5 M% j/ T& S2 d! s/ g
cd1.enabled=false2 T% k$ j- L! L: l% p! F2 }
% R. I. s; h Y' ^
end sub2 L2 l6 ?1 u, Y/ [6 U
* U7 ?+ B; k& J% R6 }! D 连接之后就是如何处理所收到的数据的问题了。客户端和服务器端建立连接后,如果有任何一端接收到新的数据,就会触发该端winsock控件的dataarrival事件,在响应这个事件时,可以使用getdata方法获得发送来的数据。比如可以在tcpclient的dataarrival事件中编写代码如下:
3 z6 w+ |6 S7 L S' g' P7 o; b# C4 H* h
private sub tcpclient_dataarrival(byval bytestotal as long)8 O( `0 }3 C* [* y% q" ~4 ~6 N: U
. T, V2 O3 R- s: k& { dim x as string
. H4 }/ u1 l' s8 d, z7 V% }! w2 a# g+ S2 a0 v! ~/ G
tcpclient.getdata x '使用getdata获得发送来的数据
n: y) n6 A7 H5 ^3 U
% x$ r6 v6 Q( z8 ^. v .......
0 a; Q6 x. |) l* t2 Q
; j& }# v& Y. b End sub
- C' P! V( j* t* f3 ? f+ p" e5 t0 x" v8 R) B8 B- H
后面的省略部分表示对接收到的数据进行的具体处理,读者可以根据实际情况编写。
3 v4 }3 ` G7 q4 d5 g( L' B7 x. F" `1 D2 F# x5 _
三、编写服务器端程序
# q4 ~3 W% O* o
& n: \; M$ n- @* D% q( M7 _ 先建立一个窗体,加载Winsock控件,名称为tcpserver。另外在窗体上加入一个文本框text1用来显示客户机的IP地址和客户机发送过来的数据信息。
" j3 l4 ^ ~% n7 ^ l5 q' j# |& Y" a3 C+ q& F) R4 ]0 P1 F( {
当客户端程序运行时,在客户端程序按下连接按钮后,客户端向服务器端程序请求连接,这时服务器端的connectionrequest事件被触发,所以服务器端程序要解决连接问题,可以使用connectionrequest事件完成此功能。代码如下:( u) r- F* J, Z
* z. N0 m5 n9 d3 O6 o
'在窗体的load事件中对tcpserver控件进行初始化& w+ `) x: m: \7 _; y; Q. m
3 m+ f5 _" K( v- Y0 m; D private sub form_load(). C( ]7 |1 {" U0 n: Q: Y# a6 o) q1 y
0 d" O; h; x, ]* A+ Y
tcpserver.localport=1001
! ]' @9 Y/ I- }- R5 d6 S+ r! f7 O7 `! c) U
tcpserver.listen '把服务器置于监听检测状态4 M! J& P5 N3 [; N
9 `/ P. X9 v0 ^& z
end sub- p8 {8 ] b Z7 G. [
% T! k1 Y+ B$ y, ?# V7 e8 t; `
'服务器端接收到客户端的连接请求,首先检查当前状态是否处于连接关闭状态& t+ P- j' d. y- U- \
* J# v' r+ |5 l# M9 O Private sub tcpclient_connectionrequest(Byval requestID as long)
; h* R1 V; t+ W/ g( Y5 t4 A, P8 F) r! M8 A5 `
If tcpserver.state<>sckclosed then '检查控件的state属性是否为关闭% p9 d# S6 C& q' X6 g
. T; {! {& N5 M
Tcpserver.close '
/ E; A( m% s. t, k9 ~1 t; O) \, ]9 z, q, w* U. z, ~& m% p% G
Tcpserver.accept requestID '8 H( `5 Y2 v E! d0 s
- l- L1 N7 P5 n8 D( W9 @2 o
End if: e- w+ Y# _! t+ z' v
* ~0 w" \2 g( C, Z3 J' \2 }+ X' f* S End sub$ w( d4 _; G2 i% S+ C6 o1 \' K' Q
1 r2 @6 E* U+ B6 Z( K
现在我们在服务器端程序tcpserver的dataarrival事件中添加以下代码,以便让服务器端程序可以接收客户机端的指令,并运行相应的程序。
5 P4 \7 u) |- }9 p: P9 c' x( s
, R1 }" y1 j% L( W 四、测试远程控制程序. F" C# M7 g2 z# k( e
: i( }: C" ?9 ]0 x2 \; U
现在,你就可以将这两个程序分别运行于两台使用TCP/IP协议联网的机器了。在客户机端你按下连接按钮,再输入“c: mmand.com”,可以看到在服务器端立刻打开一个DOS窗口,设想一下,如果它运行一些破坏性的命令会发生什么事情?这就是一个最基本的远程控制程序。当然,真正的黑客程序要复杂得多,但基本原理是相同的。现在你该恍然大悟了吧?
) F& L: ]$ z9 i! ~+ i |
|