QQ尾巴病毒

QQ尾巴病毒這種病毒並不是利用QQ本身的漏洞進行傳播。它其實是在某個網站首頁上嵌入了一段惡意代碼,利用IE的iFrame系統漏洞自動運行惡意木馬程式,從而達到侵入用戶系統,進而藉助QQ進行垃圾信息傳送的目的。

病毒主要特徵

用戶系統如果沒安裝漏洞補丁或沒把IE升級到最高版本,那么訪問這些網站的時候其訪問的網頁中嵌入的惡意代碼即被運行,就會緊接著通過IE的漏洞運行一個木馬程式進駐用戶機器。然後在用戶使用QQ向好友傳送信息的時候,該木馬程式會自動在傳送的訊息末尾插入一段廣告詞,通常都是以下幾句中的一種。

QQ收到信息如下:

1. HoHo~~ http://www.mm**.com剛才朋友給我發來的這個東東。你不看看就後悔喔,嘿嘿。也給你的朋友吧。
2. 呵呵,其實我覺得這個網站真的不錯,你看看http://www.ktv***.com/ 3. 想不想來點搖滾粗口舞曲,中華 DJ 第一站,網址告訴你http://www.qq33**.com.。不要告訴別人 ~ 哈哈,真正算得上是國內最棒的 DJ 站點。
4. http//http://www.hudong.com/wiki/www.hao***.com 幫忙看看這個網站打不打的開。
5.http://ni***.126.com 看看啊。 我最近照的照片~ 才掃描到網上的。看看我是不是變了樣?

清除方法

1.在運行中輸入MSconfig,如果啟動項中有“sendmess.exe”和“wwwo.exe”這兩個選項,將其禁止。在C:\WINDOWS一個叫qq32.INI的檔案,檔案裡面是附在QQ後的那幾句廣告詞,將其刪除。轉到DOS下再將“Sendmess.exe”和“wwwo.exe”這兩個檔案刪除。
2.安裝系統漏洞補丁
由病毒的播方式我們知道,“QQ尾巴”這種木馬病毒是利用IE的iFrame傳播的,即使不執行病毒檔案,病毒依然可以藉由漏洞自動執行,達到感染的目的。因此應該敢快下載IE的iFrame漏洞補丁。
========================================================
“QQ尾巴”專殺工具
類型: 專殺工具
版本: 2006.2.9.21
大小: 176 KB
語言: 中文
下載地址:http://tool.duba.net/zhuansha/34.shtml

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.

總結:

上面只講述了QQ訊息自動傳送的主要功能,這或許跟QQ尾巴的原理不同(我也不知道),但總體上應該差不多。如果要做到讓用戶感覺不到異常,就要改一下了,不要自動傳送,而是在當用戶點擊了“傳送”按鈕後再把文本加進去。這樣的話可是攔截“傳送”按鈕的點擊訊息,然後再用上述方法把文本加進去,然後把訊息交還原程式處理。至於如何讓它成為病毒,會自我複製,自我隱藏等功能,那又是另外一個話題了,在此就不多講了。

相關詞條

相關搜尋

熱門詞條

聯絡我們