命名对象继承1-验证Create*命名对象安全属性的传递

来源:互联网 发布:mac ps2017怎么破解 编辑:程序博客网 时间:2024/05/29 12:40

windows核心编程 第5版 48页 下半部写道

进程B调用CreateMutex时,它会向函数传递安全属性信息和第二参数。如果已经存在一个指定名称的对象,这些对象就会被忽略

 

于是我通过代码来验证这句话

注意 第47页

这个函数调用创建一个新的互斥量内核对象,并将其命名为“JeffMutex”。注意,在进程A的句柄(表)中,hMutexProcessA并不是一个可继承的句柄-但是通过为对象命名来实现共享时,是否可以继承并非一个必要条件。

 

    HANDLE hMutex1 = CreateMutex(NULL, FALSE, TEXT("JeffObj")); //创建命名对象句柄1    SECURITY_ATTRIBUTES sa;  //设置句柄安全性    sa.nLength = sizeof(sa);    sa.lpSecurityDescriptor = NULL;    sa.bInheritHandle = TRUE;    HANDLE hMutex2 = CreateMutex(&sa, FALSE, TEXT("JeffObj")); //创建对象句柄2    DWORD a;    if ((a = GetLastError()) == ERROR_ALREADY_EXISTS){  //判断创建对象句柄2是创建一个对象句柄还是调用对象句柄1    }    else {    }    DWORD dwFlags1;    GetHandleInformation(hMutex1, &dwFlags1); //验证对象句柄1的安全性是否为可继承    BOOL fHandleIsInheritable1 = (0 != (dwFlags1 & HANDLE_FLAG_INHERIT));    DWORD dwFlags2;    GetHandleInformation(hMutex2, &dwFlags2); //验证对象句柄2的安全性是否为可继承,判断继承安全性是否成功    BOOL fHandleIsInheritable2 = (0 != (dwFlags2 & HANDLE_FLAG_INHERIT));    CloseHandle(hMutex1);    CloseHandle(hMutex2);

 

结果下图

 

通过fHandleIsInheritable1和fHandleIsInheritable2 的值可以看到,2个值不同,所以命名对象句柄的安全性继承失败

 

 

0 0