1. void APCKernelRoutine(PKAPC pKAPC,
  2. PKNORMAL_ROUTINE pUserAPC,
  3. PVOID pContext,
  4. PVOID pSysArg1,
  5. PVOID pSysArg2)
  6. {
  7. DbgPrint("APCKernelRoutine Entered\n");
  8. ExFreePool(pKAPC);
  9. }
  10. NTSTATUS InjectDllByAPC(ULONG TargetPid, ULONG TargetTid, PUNICODE_STRING usDllPath, ULONG LdrMethodAddress)
  11. {
  12. ULONG size;
  13. PKTHREAD TargetThread;
  14. PEPROCESS TargetProcess;
  15. KAPC_STATE ApcState; ULONG arg1 = 0;
  16. ULONG arg2 = 0;
  17. ULONG arg3 = 0;
  18. DbgPrint("Inside InjectDllByAPC...\n");  size = (unsigned char*)APCMdlCodeEnd - (unsigned char*)APCMdlCode;
  19. DbgPrint("Allocating MDL (1)...\n"); pMDLApcCode = IoAllocateMdl(APCMdlCode, size, FALSE, FALSE, NULL);
  20. if (!pMDLApcCode)
  21. {
  22. return(STATUS_UNSUCCESSFUL);
  23. }
  24. MmProbeAndLockPages(pMDLApcCode, KernelMode, IoWriteAccess);
  25. RtlZeroMemory(pAPCData, sizeof( pAPCData));
  26. memcpy( (char*) pAPCData, usDllPath->Buffer, usDllPath->Length);
  27. unicodeLengthInfo = *(ULONG*) usDllPath;
  28. pMDLApcData = IoAllocateMdl (pAPCData, sizeof(pAPCData), FALSE,FALSE,NULL);
  29. if (!pMDLApcData)
  30. {
  31. return STATUS_UNSUCCESSFUL;
  32. }
  33. MmProbeAndLockPages(pMDLApcData, KernelMode, IoWriteAccess);    PsLookupProcessByProcessId((HANDLE)TargetPid, &TargetProcess);
  34. DbgPrint("Pid: %d, PEPROCESS: 0X%X\n", TargetPid, TargetProcess);
  35. PsLookupThreadByThreadId ((PVOID) TargetTid, &TargetThread);
  36. DbgPrint("Tid: %d, PKTHREAD: 0X%X\n", TargetTid, TargetThread);  KeStackAttachProcess((PKPROCESS) TargetProcess, &ApcState);
  37. pMappedCode = (PVOID*) MmMapLockedPagesSpecifyCache(pMDLApcCode, UserMode, MmCached, NULL, FALSE, NormalPagePriority);
  38. pMappedData = (PVOID*) MmMapLockedPagesSpecifyCache(pMDLApcData, UserMode, MmCached, NULL, FALSE, NormalPagePriority);  KeUnstackDetachProcess (&ApcState);
  39. arg1 = (ULONG) LdrMethodAddress;
  40. arg2 = (ULONG) pMappedData;
  41. arg3 = (ULONG) unicodeLengthInfo;
  42. pKAPC = (PKAPC) ExAllocatePool( NonPagedPool, sizeof(KAPC) );
  43. RtlZeroMemory(pKAPC, sizeof(KAPC));
  44. KeInitializeApc(pKAPC, TargetThread, OriginalApcEnvironment,
  45. (PKKERNEL_ROUTINE)APCKernelRoutine, NULL,
  46. (PKNORMAL_ROUTINE) pMappedCode,
  47. UserMode, (PVOID)arg1);  KeInsertQueueApc(pKAPC, (PVOID)arg2, (PVOID)arg3, 0);
  48. //KETHREAD.ApcState.UserApcPending = 1
  49. //*((unsigned char *)TargetThread + 0x4a) = 1; //XP, 2K3 RTM
  50. //*((unsigned char *)TargetThread + 0x3e) = 1; //2K3 SP1, SP2
  51. //*((unsigned char *)TargetThread + 0x4e) = 1; //Vista
  52. *((unsigned char *)TargetThread + 0x56) = 1; //Win 7
  53. if (pMDLApcCode)
  54. {
  55. MmUnlockPages(pMDLApcCode);
  56. IoFreeMdl(pMDLApcCode);
  57. }   if (pMDLApcData)
  58. {
  59. MmUnlockPages(pMDLApcData);
  60. IoFreeMdl(pMDLApcData);
  61. }
  62. ObDereferenceObject(TargetProcess);
  63. ObDereferenceObject(TargetThread);  return STATUS_SUCCESS;
  64. }
  65. void APCMdlCode(PVOID lpLdrLoadDll, PVOID pwsDllPath, PVOID pwsDllPathLength)
  66. {
  67. UNICODE_STRING usDllName;
  68. ULONG DllCharacteristics = 0;
  69. PVOID DllHandle = 0;
  70. usDllName.Length = (USHORT) pwsDllPathLength;
  71. usDllName.MaximumLength = usDllName.Length + 2;
  72. usDllName.Buffer = (WCHAR*) pwsDllPath;
  73. __asm
  74. {
  75. pushad      lea eax, DllHandle
  76. push eax
  77. lea eax, usDllName
  78. push eax
  79. lea eax, DllCharacteristics
  80. push eax
  81. push 0
  82. call [lpLdrLoadDll]   nop
  83. nop
  84. popad   }
  85. }
  86. void APCMdlCodeEnd()
  87. {
  88. }

APC注入DLL(win7下有问题)的更多相关文章

  1. 分析恶意驱动(进程启动apc注入dll)

    一.前言  用IDA也有好些时间了,以前就只会用F5功能玩无壳无保护的裸驱动,感觉太坑了,这两天就开始看网上大牛的逆向. 今天记录一下sudami曾经逆向过的fuck.sys.第一遍自己走的时候漏掉了 ...

  2. Dll注入:Ring3 层 APC注入

    APC,即Asynchronous procedure call,异步程序调用APC注入的原理是:在一个进程中,当一个执行到SleepEx()或者WaitForSingleObjectEx()时,系统 ...

  3. Dll注入技术之APC注入

    APC注入的原理是利用当线程被唤醒时APC中的注册函数会被执行的机制,并以此去执行我们的DLL加载代码,进而完成DLL注入的目的,其具体流程如下:     1)当EXE里某个线程执行到SleepEx( ...

  4. DLL注入-APC注入

    APC注入 APC注入的原理是利用当线程被唤醒时APC中的注册函数会被执行的机制,并以此去执行我们的DLL加载代码,进而完成DLL注入的目的,其具体流程如下:     1)当EXE里某个线程执行到Sl ...

  5. win7下的PHP+IIS配置,找不到php5isapi.dll的问题,版本5.4.9

    原文:win7下的PHP+IIS配置,找不到php5isapi.dll的问题,版本5.4.9 问题:PHP新手配置,在官网上下载的压缩包.按网上的找的教程配置IIS时发现,在解压包里找不到php5is ...

  6. win8和win7下解决php5.3和5.4、5.5等不能加载php_curl.dll的终极解决办法 收藏

    win8和win7下解决php5.3和5.4.5.5等不能加载php_curl.dll的终极解决办法 收藏2015年01月11日 最近分别在WIN7和Windows8 上分别安装php 高版本!都遇到 ...

  7. win7 下注册dll文件失败

    1.win7 下注册dll文件失败,提示模块“xx.dll”已加载,但找不到入口点DllRegisterServer 原因:该dll文件非可注册组件,没有包含DllRegisterServer函数,可 ...

  8. D2007在win7下bordbk105N.dll 莫名其妙的问题。

    已经装过一次win7下d2007.再装一次就出现许多莫名其妙的问题.其中之一: Windows 7 64bit Delphi Debugger Fix / Workaround 2013-08-28 ...

  9. Windows x86/ x64 Ring3层注入Dll总结

    欢迎转载,转载请注明出处:http://www.cnblogs.com/uAreKongqi/p/6012353.html 0x00.前言 提到Dll的注入,立马能够想到的方法就有很多,比如利用远程线 ...

随机推荐

  1. java中文件下载的思路(参考:孤傲苍狼)

    文件下载 文件下载功能是web开发中经常使用到的功能,使用HttpServletResponse对象就可以实现文件的下载 文件下载功能的实现思路: 1.获取要下载的文件的绝对路径 2.获取要下载的文件 ...

  2. python培训拾遗

    20140421 1. 三大利器: dir----列出所有内部方法 a=1 dir(a) 可以列出所有内部方法,就是带两个下划线的:带一个下划线的是普通方法 help---查看帮助 help(a.bi ...

  3. TotoiseSVN + VisualSVN Server 使用

    1.SVN中  项目文件版本  分服务器的版本和本地的版本.服务器版本(SVN会自动给每个版本加版本号的)永远都是最新的. 2.svn的更新,在文件不冲突的时候,会自动将服务器的版本和本地的版本合并. ...

  4. Thymeleaf 模板布局三种区别

  5. 1、Locust压力测试环境搭建

    环境准备:阿里云服务器一台.python2.7.pip Locust 介绍 Locust 是一个开源负载测试工具.使用 Python 代码定义用户行为,也可以仿真百万个用户. Locust 简单易用, ...

  6. 9、TestNG介绍与安装

    介绍 TestNG是一个受JUnit和NUnit启发的测试框架,但引入了一些新功能,使其更加强大和易于使用,例如: 注释. 在任意大的线程池中运行你的测试,这些线程池有各种可用的策略(所有方法在他们自 ...

  7. 剑指offer第二版面试题8:用两个栈实现队列(JAVA版)

    题目:用两个栈实现一个队列.队列的声明如下,请实现它的两个函数appendTail和deletedHead,分别完成在队列尾部插入节点和在队列头部删除节点的功能. 分析: 我们通过一个具体的例子来分析 ...

  8. Switch控制器

    比如目前有qq和百度两个网站,switch可以指定选择一个 Switch value是填写索引值,从0开始.也可以书去请求的名词比如,qq或者百度 填写0就是访问qq 填写1就是访问百度

  9. 基于OpenResty与Consul实现服务网格ServiceMesh

    一.逻辑架构 1.基于OpenResty开发智能代理: 利用其动态可编程特性,动态化配置nginx服务路由: 2.需要向OpenResty添加weibo开源的upsync服务发现模块: 3.基于con ...

  10. JavaScript中的面向对象编程,详解原型对象及prototype,constructor,proto,内含面向对象编程详细案例(烟花案例)

    面向对象编程:   面向:以什么为主,基于什么模式 对象:由键值对组成,可以用来描述事物,存储数据的一种数据格式 编程:使用代码解决需求   面向过程编程:         按照我们分析好的步骤,按步 ...