[转载]通过PsGetCurrentProcess函数获取函数名

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了[转载]通过PsGetCurrentProcess函数获取函数名相关的知识,希望对你有一定的参考价值。

本文转载自: http://www.cnblogs.com/xiaojinma/archive/2012/12/07/2806543.html

 

通过PsGetCurrentProcess函数来获取当前调用驱动的进程的EPROCESS结构的地址.EPROCESS结构的0x174偏移处存放着进程名.


思路如下:
驱动程序的加载函数DriverEntry是运行在System进程中的.
(1) 通过PsGetCurrentProcess可以获取System进程的内核EPROCESS结构的地址,
(2) 从该地址开始寻找"System"字符串.
(3) 找到了便是EPROCESS的进程名存放的偏移处,得到进程名在EPROCESS结构的偏移后,
(4) 进程调用驱动的时候,就可以直接在该偏移处获取当前进程名.


代码如下:

DWORD GetProcessNameOffset()
{

    PEPROCESS curproc;
    DWORD procNameOffset;
    //获取EPROCESS结构的地址
    curproc = PsGetCurrentProcess();
    for(int i=0; i< 4096; i++)
    {
        if( !strncmp( "System", (PCHAR) curproc + i, strlen("System") ))
        {
            procNameOffset = i;
            return procNameOffset;
        }
    }
    return 0;
}

以上是关于[转载]通过PsGetCurrentProcess函数获取函数名的主要内容,如果未能解决你的问题,请参考以下文章

转载: 通过反射操作类的私有属性

JAVA通过JDBC连接Oracle数据库详解转载

转载-ActiveMQ通过JAAS实现的安全机制

MFC通过URL下载并保存文件代码 转载

gson解析通过okhttp获取的json格式数据(转载)

IOS开发通过代码方式使用AutoLayout (NSLayoutConstraint + Masonry) 转载