关于windows下高低权限的管道通信问题教程

2021-06-13 15:06:00

今天在编程时遇到一个问题

我需要两个不同的进程之间通信,随后去查找了资料.找到了管道通信的方式.便去尝试.
实验的时候一切正常.但当服务端在管理员状态运行时便无法连接了.
查看连接的错误代码,是"拒绝访问"便将连接端也放在了管理员下运行,成功.
随后又不停的找资料.发现创建管道的函数"CreateNamedPipe"其中的最后一个参数lpSecurityAttributes 是用来设置管道安全性的:更改安全性的代码如下

    //创建一个安全性对象
    SECURITY_ATTRIBUTES sa;
    //管道句柄
    HANDLE hPipe;
    //
    PSECURITY_DESCRIPTOR pSD = NULL;


    pSD = (PSECURITY_DESCRIPTOR)LocalAlloc(LPTR,
        SECURITY_DESCRIPTOR_MIN_LENGTH);
    if (NULL == pSD)
    {
        
    }
    
    if (!InitializeSecurityDescriptor(pSD,
        SECURITY_DESCRIPTOR_REVISION))
    {
        
    }
    
    if (!SetSecurityDescriptorDacl(pSD,
        TRUE,     // bDaclPresent flag   
        NULL,        //将安全性设为最低
        FALSE))   // not a default DACL 
    {
        
    }

    sa.nLength = sizeof(SECURITY_ATTRIBUTES);
    sa.lpSecurityDescriptor = pSD;
    sa.bInheritHandle = FALSE;


    hPipe = CreateNamedPipe(L"\\\\.\\Pipe\\mypipe", PIPE_ACCESS_DUPLEX , PIPE_TYPE_MESSAGE | PIPE_READMODE_MESSAGE | PIPE_WAIT , PIPE_UNLIMITED_INSTANCES, 0, 0, NMPWAIT_WAIT_FOREVER, &sa);

参考文章:
1.https://docs.microsoft.com/en-us/windows/win32/api/winbase/nf-winbase-createnamedpipea
2.https://docs.microsoft.com/en-us/windows/win32/api/securitybaseapi/nf-securitybaseapi-setsecuritydescriptordacl
3.https://www.cnblogs.com/BoyXiao/archive/2011/01/02/1924188.html

当前页面是本站的「Baidu MIP」版。发表评论请点击:完整版 »