我爱电脑技术论坛's Archiver

476304467 发表于 2008-4-24 17:24

黑软编程练习-用VB制作远程控制软件

只要掌握了原理,你也能写出一个所谓的“黑客”程序。下面介绍编写一个简单的远程控制程序。从而揭开它的神秘面纱。
IUuk'P$]b
ST"JaV3S!]"VQ0M   一、所用控件 PBapvT
;z8doP)}NE
  在程序中将使用Winsock控件。Winsock控件是一个ActiveX控件,使用TCP协议或UDP协
"]U,r*YyOe;P 议连接到远程计算机上并与之交换数据。和定时器控件一样,Winsock控件在运行时是不可见的。Winsock的工作原理是:客户端向服务器端发出连接请求,服务器端则不停地监听客户端的请求,当两者的协议沟通时,客户端和服务器端之间就建立了连接,这时客户端和服务器端就可以实现双向数据传输。实际编程中,必须分别建立一个服务器端应用程序和一个客户端应用程序,两个应用程序中分别有自己的Winsock控件。首先设置Winsock控件使用的协议,这里我们使用TCP协议。现在,让我们开始用VB建立两个程序,一个是客户端程序myclient,另一个是服务器端程序myserver。 U`\$fj'g*wH

~1zt$u+s ke   二、编写客户端程序 f!E7bu ou)} C5t

_6j/k`$Hi   首先来建客户端程序myclient。在myclient程序中建立一个窗体,加载Winsock控件,称为tcpclient,表示使用的是TCP协议,再加入两个文本框(text1和text2),用来输入服务器的IP地址和端口号,然后建立一个按钮(cd1),用来建立连接,按下之后就可以对连接进行初始化了,代码如下:
aph{!`EO8U
(u Z%\M/mi(Y   private sub cd1_click()GCbB3ike_
z7wPIR,D L
  tcpclient.romotehost=text1.text
-z"Ys_U@+dUr ` Eq)QM[4{~
  tcpclient.romoteport=val(text2.text)'端口号,缺省为1001(z![e`e3Srd#`#\
#b$R\Z7`2Y
  tcpclient.connect '调用connect方法,与指定IP地址的计算机进行连接
{:S+U)A*y R$z'k fTEo3l
  cd1.enabled=false N pPtW];T-p3L

9CoM]aH   end sub
$hM B5{2c#j
H8{ C+rFu   连接之后就是如何处理所收到的数据的问题了。客户端和服务器端建立连接后,如果有任何一端接收到新的数据,就会触发该端winsock控件的dataarrival事件,在响应这个事件时,可以使用getdata方法获得发送来的数据。比如可以在tcpclient的dataarrival事件中编写代码如下:
%u'o!bc|o u.~m uo
]~pL6n*xD2nTV   private sub tcpclient_dataarrival(byval bytestotal as long)
fo*E%OB eI y'~&j&[ri
  dim x as string +V+F7sb$a/C{%dD g
R!hY2Xwo`
  tcpclient.getdata x '使用getdata获得发送来的数据
O$c4Z9[Mr-GP^v
"~,b!~N4K5Db   .......
l*a.cC4jtO
7}-F(b3p(j [GWY   End sub
0g\[oj"y:n!A
F E/K.R0zO/eQ(l   后面的省略部分表示对接收到的数据进行的具体处理,读者可以根据实际情况编写。
i5Y \l w tZ9d.yLX
k/`F/p9IH4w   三、编写服务器端程序
/We |"?(v Ha wt6GW
`A_*K(v8a   先建立一个窗体,加载Winsock控件,名称为tcpserver。另外在窗体上加入一个文本框text1用来显示客户机的IP地址和客户机发送过来的数据信息。
"^vB5EKV9S g
Nkt~ WW   当客户端程序运行时,在客户端程序按下连接按钮后,客户端向服务器端程序请求连接,这时服务器端的connectionrequest事件被触发,所以服务器端程序要解决连接问题,可以使用connectionrequest事件完成此功能。代码如下:
X Qhh2Kw
q indx+A   '在窗体的load事件中对tcpserver控件进行初始化
q7V9a&C-A"C7V a@T:\Ie sM0T
  private sub form_load()h@hC8u0e'S4R
y~E}7LP
  tcpserver.localport=1001(f6D ^$z&O$Aj(IA

$TA!Z2mBS-B9D)no   tcpserver.listen '把服务器置于监听检测状态
}Jt'viP!RP
0g!{ e$s/B2Zr   end sub
&Se%f} mr
{K{.Y:{   '服务器端接收到客户端的连接请求,首先检查当前状态是否处于连接关闭状态/l^-Y _$yM
$O NT p5S }H|T
  Private sub tcpclient_connectionrequest(Byval requestID as long)
u`/f,e ^ w V"z%c*_\}#VfjurS
  If tcpserver.state<>sckclosed then '检查控件的state属性是否为关闭
|a:Q0AR J'P 'L;D^,q!h0V_
  Tcpserver.close '
$S7I+~w-n d\;w)VC2R
  Tcpserver.accept requestID 'b-?rWr

Fw"}&]&yEe+[   End if/Q2n qOM3wD2w

Is&Mq-|~+z1g/Y   End sub4O%u[ rj&A1d1j

2V'Vh8Nj8[U|5Uvp   现在我们在服务器端程序tcpserver的dataarrival事件中添加以下代码,以便让服务器端程序可以接收客户机端的指令,并运行相应的程序。
YFHh3aw
8vq*P*P],f   四、测试远程控制程序&H#aW gZG"]5D2m

.v|8q8^;jRt/D;i   现在,你就可以将这两个程序分别运行于两台使用TCP/IP协议联网的机器了。在客户机端你按下连接按钮,再输入“c:mmand.com”,可以看到在服务器端立刻打开一个DOS窗口,设想一下,如果它运行一些破坏性的命令会发生什么事情?这就是一个最基本的远程控制程序。当然,真正的黑客程序要复杂得多,但基本原理是相同的。现在你该恍然大悟了吧?

黑侠 发表于 2008-4-24 17:27

学习了,课程不错啊,支持一下了。:)13)

kaysnoopy 发表于 2008-4-24 17:31

高手的天堂。。不是我的。。

幼儿园小班 发表于 2008-5-11 01:43

建议用写黑软的朋友注意Wi:Qjf.Z;e4u(J

nlx$jbx#[$n2B 写黑软记住要对发送的数据进行加密
/]5KJ;d }*H,x &~5`M@*s!G
不然很不安全、

紫月不追风 发表于 2008-5-11 13:09

支持4楼的观点[;q30]

luyigoog 发表于 2008-5-13 01:34

不错哦,希望搞多点VB教程哦,支持!

yidjmh 发表于 2008-5-15 22:08

:)13) 学习了~

key2004 发表于 2008-5-23 20:15

支持一下了。

页: [1]

Powered by 我爱电脑技术论坛 Archiver 6.1.0  © 2001-2007 本SEO插件由网络人站长论坛出品