• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            隨筆 - 74, 文章 - 0, 評論 - 26, 引用 - 0
            數據加載中……

            Enumhandle

            here it is .. you need the DDK for that , Gary Nebbett is the author:

            #include "ntdll.h"
            #include <stdlib.h>
            #include <stdio.h>
            #include "ntddk.h"

            #define DUPLICATE_SAME_ATTRIBUTES 0x00000004

            #pragma comment(lib,"ntdll.lib")

            BOOL EnablePrivilege(PCSTR name)
            {
            TOKEN_PRIVILEGES priv = {1, {0, 0, SE_PRIVILEGE_ENABLED}};
            LookupPrivilegeValue(0, name, &priv.Privileges[0].Luid);

            HANDLE hToken;
            OpenProcessToken(GetCurrentProcess(), TOKEN_ADJUST_PRIVILEGES, &hToken);

            AdjustTokenPrivileges(hToken, FALSE, &priv, sizeof priv, 0, 0);
            BOOL rv = GetLastError() == ERROR_SUCCESS;

            CloseHandle(hToken);
            return rv;
            }

            int main(int argc, char *argv[])
            {
            if (argc == 1) return 0;

            ULONG pid = strtoul(argv[1], 0, 0);

            EnablePrivilege(SE_DEBUG_NAME);

            HANDLE hProcess = OpenProcess(PROCESS_DUP_HANDLE, FALSE, pid);

            ULONG n = 0x1000;
            PULONG p = new ULONG[n];

            while (NT::ZwQuerySystemInformation(NT::SystemHandleInformation, p, n * sizeof *p, 0)
            == STATUS_INFO_LENGTH_MISMATCH)

            delete [] p, p = new ULONG[n *= 2];

            NT::PSYSTEM_HANDLE_INFORMATION h = NT::PSYSTEM_HANDLE_INFORMATION(p + 1);

            for (ULONG i = 0; i < *p; i++) {

            if (h[i].ProcessId == pid) {
            HANDLE hObject;

            if (NT::ZwDuplicateObject(hProcess, HANDLE(h[i].Handle), NtCurrentProcess(), &hObject,
            0, 0, DUPLICATE_SAME_ATTRIBUTES)
            != STATUS_SUCCESS) continue;

            NT::OBJECT_BASIC_INFORMATION obi;

            NT::ZwQueryObject(hObject, NT::ObjectBasicInformation, &obi, sizeof obi, &n);

            printf("%p %04hx %6lx %2x %3lx %3ld %4ld ",
            h[i].Object, h[i].Handle, h[i].GrantedAccess,
            int(h[i].Flags), obi.Attributes,
            obi.HandleCount - 1, obi.PointerCount - 2);

            n = obi.TypeInformationLength + 2;

            NT::POBJECT_TYPE_INFORMATION oti = NT::POBJECT_TYPE_INFORMATION(new CHAR[n]);

            NT::ZwQueryObject(hObject, NT::ObjectTypeInformation, oti, n, &n);

            printf("%-14.*ws ", oti[0].Name.Length / 2, oti[0].Name.Buffer);

            n = obi.NameInformationLength == 0
            ? MAX_PATH * sizeof (WCHAR) : obi.NameInformationLength;

            NT::POBJECT_NAME_INFORMATION oni = NT::POBJECT_NAME_INFORMATION(new CHAR[n]);

            NTSTATUS rv = NT::ZwQueryObject(hObject, NT::ObjectNameInformation, oni, n, &n);
            if (NT_SUCCESS(rv))
            printf("%.*ws", oni[0].Name.Length / 2, oni[0].Name.Buffer);

            printf("\n");

            CloseHandle(hObject);
            }
            }
            delete [] p;

            CloseHandle(hProcess);

            return 0;
            }

            posted on 2008-11-28 16:30 井泉 閱讀(379) 評論(0)  編輯 收藏 引用

            99久久综合国产精品二区| 久久免费看黄a级毛片| 中文精品久久久久国产网址| 色综合合久久天天综合绕视看| 国产激情久久久久影院老熟女| 久久免费99精品国产自在现线 | 99久久99久久精品国产片果冻| 久久嫩草影院免费看夜色| 亚洲精品国精品久久99热一| 一本伊大人香蕉久久网手机| 精品国产青草久久久久福利| 久久国产乱子伦精品免费强| 人妻精品久久无码区| 97精品国产97久久久久久免费| 久久人人爽人人爽人人av东京热| 亚洲天堂久久精品| 乱亲女H秽乱长久久久| 亚州日韩精品专区久久久| 狠狠色婷婷综合天天久久丁香 | 国产精品一区二区久久精品无码| 一级a性色生活片久久无少妇一级婬片免费放 | 久久99精品国产自在现线小黄鸭 | 欧美亚洲国产精品久久| 精品国产91久久久久久久a| 久久亚洲日韩精品一区二区三区| 久久久高清免费视频| 久久久久亚洲AV成人网人人网站 | 久久久久久国产精品无码下载| 国产午夜福利精品久久2021 | 久久成人精品视频| 久久亚洲精精品中文字幕| 久久强奷乱码老熟女网站| 久久婷婷色综合一区二区| 狠狠色丁香久久婷婷综合_中| 性做久久久久久免费观看| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 久久久不卡国产精品一区二区| 99久久国产综合精品五月天喷水| 久久亚洲精品中文字幕三区| 大蕉久久伊人中文字幕| 久久996热精品xxxx|