[Assembly]汇编编写简易键盘记录器
环境:
Windows xp sp3
工具:
masm
notepad++
首先列出本次编程程序要执行的步骤:
(1)、读取键盘所输入的字符
(2)、输出到屏幕上
(3)、完善Esc、Backspace、空格、回车的输出
首先解决(1)
这里我们可以利用int 16h的中断功能读取字符缓存区的字符
mov ah,
int 16h
执行完int 16h后 ah=扫描码 al=ASCII码
例如我们输入abc后
字符缓存区如下状态

然后执行int 16h
缓存区状态如下

前面的1E61被读进了ah和al
解决(2)
既然解决了(1),也成功读取了ASCII码到al中
这时候就是输出字符到屏幕上了
这里可以用内存中的b800H~bffffH这段32KB的空间输出
B800:0000就对应屏幕上第一列第一行了
mov ax,0b800h
mov es,ax
mov ah,
mov al,
mov es:[si],ax
add si,
高位存放该字符的属性 这里ah=2代码字符以绿色输出
地位存放该字符的ASCII码 这里选择41H(A)来测试

可以明显看到左上角屏幕出现了A
最后可以编写出大概的程序如下;
assume cs:code
code segment
start:
mov cx,2h
mov si,
ints:
mov ah,
int 16h
mov bl,al
mov ax,0b800h
mov es,ax
mov al,bl
mov ah,
mov es:[si],ax
add si,
add cx,
loop ints
mov ax,4c00h
int 21h code ends
end start
执行完int16h之后就不断的往屏幕上输出,然后si+2指向下一个字符输出的屏幕地址

随便输入几个字符,可以成功在屏幕上输出
接下来优化下Esc、Backspace、空格、回车的输出
根据上面的编程,已经知道程序是根据ASCII码到屏幕上输出的,可是Esc、Backspace、空格、回车的ASCII码不太明显
这里用cmp指令判断Esc、Backspace、空格、回车的扫描码,然后再修改对应的al中的ASCII码
程序如下
assume cs:code
code segment
start:
mov cx,2h
mov si,
ints:
mov ah,
int 16h
cmp ah,1ch
je ent
cmp ah,39h
je kg
fh:mov bl,al
mov ax,0b800h
mov es,ax
mov al,bl
mov ah,
mov es:[si],ax
add si,
add cx,
loop ints
mov ax,4c00h
int 21h ent:
mov al,19h
jmp fh
kg:
mov al,07h
jmp fh code ends
end start
编译后我们依次输入Esc、空格、回车、Backspace

可以看到屏幕出现了←(Esc)•(空格)↓(回车)◘(Backspace)
最后附上各个键盘的扫描码

注意,,程序中用了死循环!
[Assembly]汇编编写简易键盘记录器的更多相关文章
- 【转载】Python编写简易木马程序
转载来自: http://drops.wooyun.org/papers/4751?utm_source=tuicool 使用Python编写一个具有键盘记录.截屏以及通信功能的简易木马. 首先准备好 ...
- Python编写简易木马程序(转载乌云)
Python编写简易木马程序 light · 2015/01/26 10:07 0x00 准备 文章内容仅供学习研究.切勿用于非法用途! 这次我们使用Python编写一个具有键盘记录.截屏以及通信功能 ...
- 小白日记48:kali渗透测试之Web渗透-XSS(二)-漏洞利用-键盘记录器,xsser
XSS 原则上:只要XSS漏洞存在,可以编写任何功能的js脚本 [反射型漏洞利用] 键盘记录器:被记录下的数据会发送到攻击者指定的URL地址上 服务器:kali 客户端 启动apache2服务:ser ...
- [C语言(VC)] 打造自己的键盘记录器 (zaroty)
说起键盘记录,想必很多朋友都用过网上流传的一些键盘记录软件吧,但是有没有想过自己写一个呢?也许你会想:会不会很复杂啊?我可以很负责的告诉你,写键盘记录是很简单的.你所需要的仅仅是懂得一些C语言的DLL ...
- C# 编写简易 ASP.NET Web 服务器
C# 编写简易 ASP.NET Web 服务器 你是否有过这样的需求——想运行 ASP.NET 程序,又不想安装 IIS 或者 Visual Studio?我想如果你经常编写 ASP.NET 程序的话 ...
- 警惕USB键盘记录器
最近媒体报道了一种新型的能记录账号.密码输入的“USB键盘记录器”,引发网友关注,该设备看上去和普通U盘没什么区别,将其插入电脑USB接口,然后把键盘线和它连接,该设备就能够自动记录用户在电脑上输入的 ...
- wpf键盘记录器
很简单的一个wpf键盘记录器 这个程序我一样用了全局勾子,之前用的都是winform上运行了,前一段时间 在国外的论坛上逛看到了一个wpf能用的就做了一个小程序记录一下,为了方便大家直关的看我在页面上 ...
- 安全之路 —— 使用Windows全局钩子打造键盘记录器
简介 键盘记录功能一直是木马等恶意软件窥探用户隐私的标配,那么这个功能是怎么实现的呢?在Ring3级下,微软就为我们内置了一个Hook窗口消息的API,也就是SetWindowsHookEx函数,这个 ...
- 6.文件所有权和权限----免费设置匿名----Windows键盘记录器----简介和python模块
文件所有权和权限 touch --help cd Desktop mkdir Folder cd Folder clear touch Test1 Test2 Test3 Test4 ls ls -l ...
随机推荐
- nginx配置浅析
一.nginx的介绍 nginx是由俄罗斯人开发的一款高性能的http和反向代理服务器,也可以用来作为邮件代理.相比较于其他的服务器,具有占用内存少,稳定性高等优势 二.nginx的配置 nginx的 ...
- NVME SSD vs SATA SSD(转)
NVMe是个啥?未来SSD主流标准早知 关注固态硬盘的朋友应该对于这个词汇并不陌生,特别是今年NVMe也频繁出现在各大媒体文章中,随着高端SSD市场逐渐从SATA专项PCI-E时,以前的AHCI标准已 ...
- 无需编译app切换线上、测试环境
在咱们测试过程中,经常需要切换测试环境和线上环境.大致有如下几个方案. 一.服务器地址编译到app中 此种方式需要在代码里保存两套配置,一套指向线上,一套指向测试.通过编译参数分别生成测试包.线上包. ...
- 你竟然在公钥中下毒!——如何在RSA公钥中添加后门
原文:http://www.hackdig.com/?01/hack-17893.htm 分享到: 当我知道它是如何运行时,我惊得下巴都掉了.这是一个非常简单的手法,但这篇文章会颠覆你之前对RSA的看 ...
- Android studio 安装过程中遇到的问题
之前用eclipse,想换下studio试试,安装时遇到问题,参考:http://www.cnblogs.com/csulennon/p/4178404.html
- 序列化 json和pickle
序列化 1. 什么叫序列化 将原本的字典.列表等内容转换成一个字符串的过程就叫做序列化. 2. json dumps loads 一般对字典和列表序列化 dump load 一般对 ...
- gif处理
UleadGIFAnimator-v5.05破解版 网盘地址:https://pan.baidu.com/s/1bpf6iVP 2017-02-19 10:39:58
- 出现丢包解决方法(ping: sendmsg: Operation not permitted)
故障排查: 早上突然收到nagios服务器check_icmp的报警,报警显示一台网站服务器的内网网络有问题.因为那台服务器挂载了内网的NFS,因此内网的网络就采用nagios的check_icmp来 ...
- 浏览器开启web通知。
https://www.cnblogs.com/xcsn/p/7767092.html
- vuejs学习--递归组件(树型表格分享)
前言 学习vue有一段时间了,最近使用vue做了一套后台管理系统,其中使用最多就是递归组件,也因为自己对官方文档的不熟悉使得自己踩了不少坑,今天写出来和大家一起分享. 递归组件 组件在它的模板内可以递 ...