DLL注入,输入法注入,驱动注入,原里各是什么?

 我来答
匿名用户
2013-07-18
展开全部
输入法注入利用了DLL数据链库文件。你可以简单的这么理解:你想修改一些东西,然后就编写一个程序,把要修改的内容和功能保存在一个DLL里面,然后注入到输入法的进程模块中,这样,只要输入法运行,你的功能就始终维持一个运行状态,达到你修改某些东西的目的。 至于系统驱动注入应该就是程序将自身的加载项与驱动的sys文件关联起来。驱动的权限较高,很多驱动程序是工作在ring0层的,驱动的加载要早于操作系统中的安全软件,因为他们是工作在ring3层的。 所谓DLL注入就是将一个DLL放进某个进程的地址空间里,让它成为那个进程的一部分。要实现DLL注入,首先需要打开目标进程。 编辑本段例:  hRemoteProcess = OpenProcess( PROCESS_CREATE_THREAD | //允许远程创建线程   PROCESS_VM_OPERATION | //允许远程VM操作   PROCESS_VM_WRITE, //允许远程VM写   FALSE, dwRemoteProcessId )   由于我们后面需要写入远程进程的内存地址空间并建立远程线程,所以需要申请足够的权限(PROCESS_CREATE_THREAD、VM_OPERATION、VM_WRITE)。   如果进程打不开,以后的操作就别想了。进程打开后,就可以建立远线程了,不过别急,先想想这个远线程的线程函数是什么?我们的目的是注入一个DLL。而且我们知道用LoadLibrary可以加载一个DLL到本进程的地址空间。于是,自然会想到如果可以在目标进程中调用LoadLibrary,不就可以把DLL加载到目标进程的地址空间了吗?对!就是这样。远线程就在这儿用了一次,建立的远线程的线程函数就是LoadLibrary,而参数就是要注入的DLL的文件名。(这里需要自己想一想,注意到了吗,线程函数ThreadProc和LoadLibrary函数非常相似,返回值,参数个数都一样) 还有一个问题,LoadLibrary这个函数的地址在哪儿?也许你会说,这个简单,GetProcAddress就可以得出。于是代码就出来了。   char *pszLibFileRemote="my.dll";   PTHREAD_START_ROUTINE pfnStartAddr = (PTHREAD_START_ROUTINE)GetProcAddress(GetModuleHandle("Kernel32"), "LoadLibraryA");   CreateRemoteThread( hRemoteProcess, NULL, 0, pfnStartAddr, pszLibFileRemote, 0, NULL);   但是不对!不要忘了,这是远线程,不是在你的进程里,而pszLibFileRemote指向的是你的进程里的数据,到了目标进程,这个指针都不知道指向哪儿去了,同样pfnStartAddr这个地址上的代码到了目标进程里也不知道是什么了,不知道是不是你想要的LoadLibraryA了。但是,问题总是可以解决的,Windows有些很强大的API函数,他们可以在目标进程里分配内存,可以将你的进程中的数据拷贝到目标进程中。因此pszLibFileRemote的问题可以解决了。   char *pszLibFileName="my.dll";//注意,这个一定要是全路径文件名,除非它在系统目录里;原因大家自己想想。   //计算DLL路径名需要的内存空间   int cb = (1 + lstrlenA(pszLibFileName)) * sizeof(char);   //使用VirtualAllocEx函数在远程进程的内存地址空间分配DLL文件名缓冲区   pszLibFileRemote = (char *) VirtualAllocEx( hRemoteProcess, NULL, cb, MEM_COMMIT, PAGE_READWRITE);   //使用WriteProcessMemory函数将DLL的路径名复制到远程进程的内存空间   iReturnCode = WriteProcessMemory(hRemoteProcess, pszLibFileRemote, (PVOID) pszLibFileName, cb, NULL);   OK,现在目标进程也认识pszLibFileRemote了,但是pfnStartAddr好像不好办,我怎么可能知道LoadLibraryA在目标进程中的地址呢?其实Windows为我们解决了这个问题,LoadLibraryA这个函数是在Kernel32.dll这个核心DLL里的,而这个DLL很特殊,不管对于哪个进程,Windows总是把它加载到相同的地址上去。因此你的进程中LoadLibraryA的地址和目标进程中LoadLibraryA的地址是相同的(其实,这个DLL里的所有函数都是如此)。至此,DLL注入结束了。
摄影爱好者一个人
2016-03-07 · TA获得超过330个赞
知道小有建树答主
回答量:249
采纳率:50%
帮助的人:114万
展开全部
.DLL命令 ImmInstallIME, 整数型, "imm32.dll", "ImmInstallIMEA", , 该函数的两个参数分别为输入法IME文件的文件名和在控制面板的是输入法选项中显示的输入法名称。函数调用后将返回一个被安装输入法的输入法标识符(或称做输入法句柄)。
.参数 lpszIMEFileName, 文本型, , 输入法的安装目录
.参数 lpszLayoutText, 文本型, , 输入法的名称

因为系统会对输入法文件进行检测 判断是否是输入法
所以我们安装好了输入法之后就再把我们的DLL对她进行覆盖 就可以把我们原先的输入法文件覆盖成我们的DLL
然后使用IMESetPubString
这个函数来对输入法注入的一些信息配置
这时候我们只完成了加载 还需要我们手动按CTRL+SHIFT键触发到我们的指定输入法

希望能帮到你
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式