XP下的进程静音技术(遍历进程,遍历输入模块,遍历输入函数,找到函数并HOOK) good
很多浏览器有这种功能,实现原理都是一样。发声源基本都来自Flash,比如Flash游戏啦,视频播放器啦等等
而Flash的发声都是通过winmm.dll::waveOutWrite函数来完成,所以,我们只要能“接管”这个函数就行了
下面的代码是以前写的一个模块,针对Flash的静音,代码写的比较粗糙 ^_^
注意,下面的代码仅仅针对Flash模块进行IAT Hook
XP测试通过
- unit FlashMute;
- interface
- uses
- Windows, SysUtils, Classes, StrUtils, TlHelp32, MMSystem;
- type
- TFlashMute = class
- private
- class var Flag: Boolean;
- public
- class function Modify_waveOutWrite: Boolean;
- class procedure Enable;
- class procedure Disable;
- end;
- implementation
- function MywaveOutWrite(hWaveOut: HWAVEOUT; lpWaveOutHdr: PWaveHdr; uSize: UINT): MMRESULT; stdcall;
- begin
- if TFlashMute.Flag then
- ZeroMemory(lpWaveOutHdr.lpData, lpWaveOutHdr.dwBufferLength);
- Result := waveOutWrite(hWaveOut, lpWaveOutHdr, uSize);
- end;
- { TFlashMute }
- class procedure TFlashMute.Disable;
- begin
- TFlashMute.Flag := True;
- end;
- class procedure TFlashMute.Enable;
- begin
- TFlashMute.Flag := False;
- end;
- class function TFlashMute.Modify_waveOutWrite: Boolean;
- var
- hSnapshot: THandle;
- ME32: TModuleEntry32;
- Found: Boolean;
- BaseAddr: DWORD;
- DosHeader: PImageDosHeader;
- NtHeader: PImageNtHeaders;
- ImportDesc: PImageImportDescriptor;
- ITD, ITD2: PImageThunkData;
- IIBN: PImageImportByName;
- mbi: TMemoryBasicInformation;
- begin
- Result := False;
- // 枚举当前进程模块列表,找到Flash?.ocx
- hSnapshot := CreateToolhelp32Snapshot(TH32CS_SNAPMODULE, GetCurrentProcessId);
- if hSnapshot <> INVALID_HANDLE_VALUE then
- begin
- ME32.dwSize := SizeOf(TModuleEntry32);
- Found := Module32First(hSnapshot, ME32);
- while Found do
- begin
- if ContainsText(ME32.szModule, 'Flash') then
- begin
- if SameText(ExtractFileExt(ME32.szModule), '.ocx') then
- begin
- BaseAddr := DWORD(@ME32.modBaseAddr^);
- DosHeader := @ME32.modBaseAddr^;
- NtHeader := Ptr(BaseAddr + DosHeader^._lfanew);
- // 遍历输入模块
- ImportDesc := Ptr(BaseAddr + NtHeader.OptionalHeader.DataDirectory[1].VirtualAddress);
- while ImportDesc^.Name <> 0 do
- begin
- ITD := PImageThunkData(BaseAddr + ImportDesc^.OriginalFirstThunk); // 指向函数名称RVA或函数序号
- ITD2 := PImageThunkData(BaseAddr + ImportDesc^.FirstThunk); // 指向函数地址
- // 遍历输入函数
- while ITD^.AddressOfData <> 0 do
- begin
- // 按函数名方式导入的函数
- if ITD^.AddressOfData and IMAGE_ORDINAL_FLAG <> IMAGE_ORDINAL_FLAG then
- begin
- IIBN := PImageImportByName(BaseAddr + ITD^.AddressOfData);
- // 找出 winmm.dll::waveOutWrite
- if SameText(string(PAnsiChar(@IIBN^.Name[0])), 'waveOutWrite') then
- begin
- if VirtualProtect(@ITD2^._Function, SizeOf(DWORD), PAGE_EXECUTE_READWRITE, @mbi.Protect) then
- begin
- ITD2^._Function := DWORD(@MywaveOutWrite);
- Result := True;
- end;
- Break;
- end;
- end;
- Inc(ITD);
- Inc(ITD2);
- end;
- if Result then
- Break;
- Inc(ImportDesc);
- end;
- end;
- end;
- if Result then
- Break;
- Found := Module32Next(hSnapshot, ME32);
- end;
- CloseHandle(hSnapshot);
- end;
- end;
http://blog.csdn.net/aqtata/article/details/8112092
XP下的进程静音技术(遍历进程,遍历输入模块,遍历输入函数,找到函数并HOOK) good的更多相关文章
- xp 下查看进程指令
xp 下快速查看进程及关联 exe 的指令,刚发现,还没有测试 win7 和 win10 支持不支持. wmic process where creationclassname="win32 ...
- Android中通过进程注入技术改动广播接收器的优先级
前言 这个周末又没有吊事,在家研究了怎样通过进程的注入技术改动广播接收器的优先级.关于这个应用场景是非常多的.并且也非常重要.所以就非常急的去fixed了. Android中的四大组件中有一个广播:B ...
- Android中通过进程注入技术修改广播接收器的优先级
前言 这个周末又没有吊事,在家研究了如何通过进程的注入技术修改广播接收器的优先级,关于这个应用场景是很多的,而且也很重要,所以就很急的去fixed了. Android中的四大组件中有一个广播:Broa ...
- delphi中获得进程列表或想要的进程(枚举进程、遍历进程)
一个常见的编程任务是枚举所有运行的"应用程序".Windows 任务管理器就是一个很好的例子.它用两种方式列出"应用程序".任务管理器的第一个选项卡列出桌面上的 ...
- Android中通过进程注入技术修改系统返回的Mac地址
致谢 感谢看雪论坛中的这位大神,分享了这个技术:http://bbs.pediy.com/showthread.php?t=186054,从这篇文章中学习到了很多内容,如果没有这篇好文章,我在研究的过 ...
- 遍历进程活动链表(ActiveProcessLinks)、DKOM隐藏进程
1.EPROCESS结构体 EPROCESS块来表示.EPROCESS块中不仅包含了进程相关了很多信息,还有很多指向其他相关结构数据结构的指针.例如每一个进程里面都至少有一个ETHREAD块表示的线程 ...
- 利用NtQuerySystemInformation函数遍历进程,遍历线程,获取线程挂起或运行状态
版权声明:专注于计算机网络安全学习 https://blog.csdn.net/u011672712/article/details/51586030 1 2 3 4 5 6 7 8 9 10 11 ...
- Python编程-多道技术和进程
一.多道技术 1.多路复用 操作系统主要使用来 记录哪个程序使用什么资源 对资源请求进行分配 为不同的程序和用户调解互相冲突的资源请求. 我们可将上述操作系统的功能总结为: 处理来自多个程序发起的多个 ...
- Windows提高_1.2遍历进程、遍历模块
进程 什么是进程? 通俗的来讲,进程就是一个运行中的程序,最少包含一个虚拟空间,通常是 4 GB大小,一组提供数据和代码的模块,通产是 dll 和 exe 文件,一个进程内核对象和最少一个线程. 进程 ...
随机推荐
- 新买一款打印机hp5525N
11900 RMB 彩色.激光.彩打. 让法国的工艺工程师给改成法语的了.
- mysql入门记录
mysql -h localhost(or ID) -u root -p show databases; create database <数据库名>: drop database < ...
- Maven和Eclipse联合开发(转)
最近公司突然把以前的架构推到从来,这个还真需要勇气,不过也是的,基础不好,再好的房子也站不稳.公司采用Maven作为项目管理,WebService项目框架采用SDHI.(Spring+Dubbo+He ...
- uva 10313 Pay the Price(完全背包)
题目连接:10313 - Pay the Price 题目大意:有0~300这300种价值的金额. 现在可能给出参数: 1个:n, 输出可以组成价值n的方式的个数. 2个:n, a输出用个数小于a的价 ...
- poj2533--Longest Ordered Subsequence(dp:最长上升子序列)
Longest Ordered Subsequence Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 33943 Acc ...
- easyUI相关知识
$("#sportGroupInfoDialog").dialog("open");//打开一个对话框,设置这个对话框的的布局方式 $('#sportGroup ...
- 字符设备驱动[深入]:linux cdev详解
linux cdev详解 http://blog.chinaunix.net/uid-24517893-id-161446.html 用cdev_add添加字符设备驱动: //linux2.6中用c ...
- Java Socket实现HTTP客户端来理解Session和Cookie的区别和联系
HTTP协议本身是无状态的,即使是同一台电脑同一个浏览器打开同一个页面两次,服务器不知道这两次请求是同一个客户端发送过来的,两次请求是完全独立的.例如,第一次请求时已经登录了,第二次再请求服务器会“忘 ...
- 如何在myeclipse有个项目文件很多,我想找一段代码,怎么查找?
然后输入要找的文字 然后在File name pathherns 中写 *.java 如果有多个就可以用逗号分隔! 然后 search
- Swift - 产生不重复数字的随机数生成器
在Swift中,可以使用函数类型的参数,也可以使用函数类型的返回值.而作为返回值的函数,还能“捕获”外部的值,并多次使用它.这个特性,常可用来创建各种生成器. 下面通过创建一个“随机数生成器函数”作为 ...