-
Notifications
You must be signed in to change notification settings - Fork 121
/
Copy pathCreateFileMapping.cpp
102 lines (88 loc) · 2.43 KB
/
CreateFileMapping.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
#include <windows.h>
#include <stdio.h>
#include <conio.h>
#include <tchar.h>
#pragma comment(lib,"Advapi32.lib")
#define BUF_SIZE 256
int main(int argc, char *argv[])
{
if (argc != 2)
{
printf("\nCreateFileMapping\n\n");
printf("Usage:\n");
printf("%s <string>\n",argv[0]);
return 0;
}
HANDLE hMapFile1, hMapFile2;
char *pBuf;
char *pBuf2;
char szName1[] = "Global\\SharedMappingObject1";
char szName2[] = "Global\\SharedMappingObject2";
DWORD EventRecordID = 32;
DWORD offset = 0x11;
char szOffset[8];
sprintf_s(szOffset, "%d", offset);
printf("[*]Try to set SecurityDescriptor... ");
PSECURITY_DESCRIPTOR pSec = (PSECURITY_DESCRIPTOR)LocalAlloc(LMEM_FIXED, SECURITY_DESCRIPTOR_MIN_LENGTH);
if (!pSec)
{
return GetLastError();
}
if (!InitializeSecurityDescriptor(pSec, SECURITY_DESCRIPTOR_REVISION))
{
LocalFree(pSec);
return GetLastError();
}
if (!SetSecurityDescriptorDacl(pSec, TRUE, NULL, TRUE))
{
LocalFree(pSec);
return GetLastError();
}
SECURITY_ATTRIBUTES attr;
attr.bInheritHandle = FALSE;
attr.lpSecurityDescriptor = pSec;
attr.nLength = sizeof(SECURITY_ATTRIBUTES);
printf("Done\n");
printf("[*]Try to CreateFileMapping1... ");
hMapFile1 = CreateFileMapping(INVALID_HANDLE_VALUE,&attr,PAGE_READWRITE,0,BUF_SIZE,szName1);
if (hMapFile1 == NULL)
{
printf("\n[!]Could not create file mapping object1 (%d).\n", GetLastError());
return 0;
}
pBuf = (char *)MapViewOfFile(hMapFile1,FILE_MAP_ALL_ACCESS,0,0,BUF_SIZE);
if (pBuf == NULL)
{
printf("\n[!]Could not map view of file1 (%d).\n", GetLastError());
CloseHandle(hMapFile1);
return 1;
}
CopyMemory((PVOID)pBuf, argv[1], strlen(argv[1]));
printf("Done\n");
printf("[*]Try to CreateFileMapping2... ");
hMapFile2 = CreateFileMapping(INVALID_HANDLE_VALUE,&attr,PAGE_READWRITE,0,BUF_SIZE,szName2);
if (hMapFile2 == NULL)
{
printf("\n[!]Could not create file mapping object2 (%d).\n", GetLastError());
return 0;
}
pBuf2 = (char *)MapViewOfFile(hMapFile2,FILE_MAP_ALL_ACCESS,0,0,BUF_SIZE);
if (pBuf2 == NULL)
{
printf("\n[!]Could not map view of file2 (%d).\n", GetLastError());
CloseHandle(hMapFile2);
return 1;
}
CopyMemory((PVOID)pBuf2, szOffset, strlen(szOffset));
printf("Done\n");
printf("Waiting...\n");
printf("[+]You can input something to stop waiting\n");
_getch();
printf("[*]Free\n");
LocalFree(pSec);
UnmapViewOfFile(pBuf);
CloseHandle(hMapFile1);
UnmapViewOfFile(pBuf2);
CloseHandle(hMapFile2);
return 0;
}