系统相关
首页 > 系统相关> > 关于windows下高低权限的管道通信问题

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

作者:互联网

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

我需要两个不同的进程之间通信,随后去查找了资料.找到了管道通信的方式.便去尝试.
实验的时候一切正常.但当服务端在管理员状态运行时便无法连接了.
查看连接的错误代码,是"拒绝访问"便将连接端也放在了管理员下运行,成功.
随后又不停的找资料.发现创建管道的函数"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

标签:windows,pSD,PIPE,DESCRIPTOR,管道,sa,权限,SECURITY
来源: https://blog.csdn.net/stars_under/article/details/117876882