VC注册表操作之设置权限

#include <Aclapi.h>
#include <shobjidl.h>
#include "Shlwapi.h"  
#include "ShlGuid.h"
#pragma comment(lib,"Shlwapi.lib")   

/****************************************************************/
//nFlags含义:
//	0	:	允许Admin_Name用户所有权限
//	1	:	拒绝Admin_Name设置值
//	2	:	拒绝Admin_Name读取
/****************************************************************/
BOOL SetRegJurisdiction(LPTSTR pObjectName, DWORD nFlags)
{
	BOOL Result = FALSE;
	TCHAR Admin_Name[]=_T("Administrators");
	PACL pOldDacl = NULL;
	PACL pNewDacl = NULL;
	DWORD dRet;
	EXPLICIT_ACCESS eia;
	PSECURITY_DESCRIPTOR pSID = NULL;
	dRet = GetNamedSecurityInfo(pObjectName, SE_REGISTRY_KEY, DACL_SECURITY_INFORMATION, NULL, NULL, &pOldDacl, NULL, &pSID);// 获取SAM主键的DACL
	if (dRet != ERROR_SUCCESS)
		goto ret:

	//创建一个ACE, 允许Administrators组成员完全控制对象, 并允许子对象继承此权限
	ZeroMemory(&eia, sizeof(EXPLICIT_ACCESS));
	switch (nFlags)
	{
	case 0:
		BuildExplicitAccessWithName(&eia, Admin_Name, KEY_ALL_ACCESS, SET_ACCESS, SUB_CONTAINERS_AND_OBJECTS_INHERIT);
		break;
	case 1:
		BuildExplicitAccessWithName(&eia, Admin_Name, KEY_SET_VALUE, DENY_ACCESS, SUB_CONTAINERS_AND_OBJECTS_INHERIT);
		break;
	case 2:
		BuildExplicitAccessWithName(&eia, Admin_Name, KEY_READ, DENY_ACCESS, SUB_CONTAINERS_AND_OBJECTS_INHERIT);
		break;
	default:
		break;
	}
	// 将新的ACE加入DACL
	dRet = SetEntriesInAcl(1, &eia, pOldDacl, &pNewDacl);
	if (dRet != ERROR_SUCCESS)
		goto ret:

	// 更新主键的DACL
	dRet = SetNamedSecurityInfo(pObjectName, SE_REGISTRY_KEY, DACL_SECURITY_INFORMATION, NULL, NULL, pNewDacl, NULL);
	if (dRet != ERROR_SUCCESS)
		goto ret:
	Result = TRUE;
ret:
	//释放DACL和SID
	if (pNewDacl)
		LocalFree(pNewDacl);
	if (pSID)
		LocalFree(pSID);
	return Result;;
}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值