zoukankan      html  css  js  c++  java
  • 劫持系统进程禁止打开任何进程(5)

    劫持系统进程禁止打开任何进程(5)
    windows创建进程的函数:


    把这个函数劫持之后注射到 explore.exe进程中即可。

    现在注射到印象笔记中测试:

    #include<stdio.h>
    #include<windows.h>
    #include<string.h>
    #include"detours.h"
    #pragma comment (lib ,"detours.lib" )

    BOOL(WINAPI * oldCreateProcessW)(
            LPCWSTR lpApplicationName,
            LPWSTR lpCommandLine,
            LPSECURITY_ATTRIBUTES lpProcessAttributes,
            LPSECURITY_ATTRIBUTES lpThreadAttributes,
            BOOL bInheritHandles,
            DWORD dwCreationFlags,
            LPVOID lpEnvironment,
            LPCWSTR lpCurrentDirectory,
            LPSTARTUPINFOW lpStartupInfo,
            LPPROCESS_INFORMATION lpProcessInformation
           ) = CreateProcessW;

    BOOL WINAPI newCreateProcessW(
            LPCWSTR lpApplicationName,
            LPWSTR lpCommandLine,
            LPSECURITY_ATTRIBUTES lpProcessAttributes ,
            LPSECURITY_ATTRIBUTES lpThreadAttributes ,
            BOOL bInheritHandles,
            DWORD dwCreationFlags,
            LPVOID lpEnvironment,
            LPCWSTR lpCurrentDirectory,
            LPSTARTUPINFOW lpStartupInfo ,
            LPPROCESS_INFORMATION lpProcessInformation
           ) {
           MessageBoxA(0, "系统进程已被劫持!" , "系统警告" , 0);
            return 0;
    }

    void Hook()
    {

           DetourRestoreAfterWith(); //恢复原来状态,
           DetourTransactionBegin(); //拦截开始
           DetourUpdateThread(GetCurrentThread()); //刷新当前线程
           DetourAttach(( void **)&oldCreateProcessW, newCreateProcessW); //实现函数拦截
           DetourTransactionCommit(); //拦截生效

    }

    void UnHook()
    {
           DetourTransactionBegin(); //拦截开始
           DetourUpdateThread(GetCurrentThread()); //刷新当前线程
           DetourDetach(( void **)&oldCreateProcessW, newCreateProcessW); //撤销拦截函数
           DetourTransactionCommit(); //拦截生效
    }

    _declspec(dllexport ) void go(){
           MessageBoxA(0, "系统进程劫持成功!" , "系统信息" , 0);
           int i = 0;
           while (i++ < 60){
                  Hook();
                  Sleep(1000);
           }
           UnHook();
    }

    劫持成功:

       


    打开帮助的入门指南的时候:





  • 相关阅读:
    redis原理及实现
    RabbitMQ原理介绍
    我的mongoDb之旅(二)
    我的mongoDb之旅(一)
    PHP服务器Apache与Nginx的对比分析
    后端技术杂谈11:十分钟理解Kubernetes核心概念
    后端技术杂谈10:Docker 核心技术与实现原理
    后端技术杂谈9:先搞懂Docker核心概念吧
    后端技术杂谈8:OpenStack架构设计
    后端技术杂谈7:OpenStack的基石KVM
  • 原文地址:https://www.cnblogs.com/ZhangJinkun/p/4531484.html
Copyright © 2011-2022 走看看