[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 ...
随机推荐
- re-sign重签名
准备: ① re-sign.jar重签名工具:(下载地址为:http://troido.de/downloads/category/1): ② 从D:\Android\sdk\build-tools\ ...
- Unity教程之-Unity3d中针对Android Apk的签名验证(C#实现)
当Unity开发的游戏以Android Apk的形式发布之后,经常会遇到的一种情况就是别人对我们的游戏进行二次打包,也就是用他们的签名替换掉我们的签名,从而堂而皇之的将胜利果实占为己有.面对这样的情况 ...
- 30 C? Go? Cgo!
C? Go? Cgo! 17 March 2011 Introduction Cgo lets Go packages call C code. Given a Go source file writ ...
- OpenJDK,Oracle's OpenJDK,Oracle JDK的区别与选择
OpenJDK 单纯的OpenJDK指的是JDK的源码,以GPL协议开源,由企业和社区开发者共同维护和开发. Oracle's OpenJDK Oracle started providing ope ...
- 决策树和adaboost
前面:好老的东西啊,啊啊啊啊啊啊啊啊啊 来源于统计学习方法: 信息增益: 其中 信息增益率: 基尼指数: 取gini最小的 先剪枝——在构造过程中,当某个节点满足剪枝条件,则直接停止此分支的构造. 后 ...
- 深入理解HashMap(及hash函数的真正巧妙之处)
原文地址:http://www.iteye.com/topic/539465 Hashmap是一种非常常用的.应用广泛的数据类型,最近研究到相关的内容,就正好复习一下.网上关于hashmap的文章很多 ...
- Description Resource Path Location Type The superclass "javax.servlet.http.HttpServlet" was not foun
一段时间没亲自建新项目玩乐,今天建立了一Maven project的时候发现了以下异常,Description Resource Path Location Type The superclass & ...
- opencv(5)GUI
OpenCV的图形用户界面(Graphical User Interface, GUI)和绘图等相关功能也是很有用的功能,无论是可视化,图像调试还是我们这节要实现的标注任务,都可以有所帮助. 窗口循环 ...
- SQL中EXCEPT和Not in的区别?
初始化两张表: CREATE TABLE tb1(ID int) INSERT tb1 SELECT NULLUNION ALL SELECT NULLUNION ...
- Alpine里的用户管理命令
注意噢,和普通的linux不一样的. 1, 建立一个指定GID的组: addgroup -g 10001 -S groupA 2, 建立一个指定UID的用户,指定shell, 让它属于指定的用户组. ...