ylting

我的用户进程需要和我的服务进程通信,通过文件映射、事件的方式通信时需要注意:

1、需要低权限

var
 SecMem: SECURITY_ATTRIBUTES;
aSD: SECURITY_DESCRIPTOR;
begin
FExistsAlready := False;

InitializeSecurityDescriptor(@aSD, SECURITY_DESCRIPTOR_REVISION);
SetSecurityDescriptorDacl(@aSD, True, nil, False);
SecMem.nLength := SizeOf(SECURITY_ATTRIBUTES);
SecMem.lpSecurityDescriptor := @aSD;
SecMem.bInheritHandle := False;

FMapHandle := CreateFileMapping($FFFFFFFF, @SecMem, PAGE_READWRITE, 0, FSize, PChar(FMapName));

2、内核对象名称必须以 Global\开头,这样创建的对象是全局的,才可以访问,否则系统进程创建的和用户进程创建的会属于不同的session

类似 Global\filemap{5CE70063-66C7-4B37-9559-C73901EA70EF}

分类:

技术点:

相关文章: