How to apply Windows group policy using .NET?

后端 未结 2 1203
广开言路
广开言路 2020-12-03 02:28

Is it possible to apply (and remove) Windows group policy settings using .NET?

I am working on an application that needs to temporarily put a machine into

相关标签:
2条回答
  • 2020-12-03 02:38

    NOTE: I use two GroupPolicy assembly references: C:\Windows\assembly\GAC_MSIL\Microsoft.GroupPolicy.Management\2.0.0.0__31bf3856ad364e35\Microsoft.GroupPolicy.Management.dll and C:\Windows\assembly\GAC_32\Microsoft.GroupPolicy.Management.Interop\2.0.0.0__31bf3856ad364e35\Microsoft.GroupPolicy.Management.Interop.dll This framework 2.0, so there are mixed code, and you must use app.config: http://msmvps.com/blogs/rfennell/archive/2010/03/27/mixed-mode-assembly-is-built-against-version-v2-0-50727-error-using-net-4-development-web-server.aspx

    I made it like that.

    using System.Collections.ObjectModel;
    using Microsoft.GroupPolicy;
    using Microsoft.Win32;
    
    /// <summary>
    /// Change user's registry policy
    /// </summary>
    /// <param name="gpoName">The name of Group Policy Object(DisplayName)</param>
    /// <param name="keyPath">Is KeyPath(like string path=@"Software\Microsoft\Windows\CurrentVersion\Policies\Explorer")</param>
    /// <param name="typeOfKey">DWord, ExpandString,... e.t.c </param>
    /// <param name="parameterName">Name of parameter</param>
    /// <param name="value">Value</param>
    /// <returns>result: true\false</returns>
    public bool ChangePolicyUser(string gpoName, string keyPath, RegistryValueKind typeOfKey, string parameterName, object value)
        {
            try
            {
                RegistrySetting newSetting = new PolicyRegistrySetting();
                newSetting.Hive = RegistryHive.CurrentUser;
                newSetting.KeyPath = keyPath;
                bool contains = false;
                //newSetting.SetValue(parameterName, value, typeOfKey);
                switch (typeOfKey)
                {
                    case RegistryValueKind.String:
                        newSetting.SetValue(parameterName, (string)value, typeOfKey);
                        break;
                    case RegistryValueKind.ExpandString:
                        newSetting.SetValue(parameterName, (string)value, typeOfKey);
                        break;
                    case RegistryValueKind.DWord:
                        newSetting.SetValue(parameterName, (Int32)value);
                        break;
                    case RegistryValueKind.QWord:
                        newSetting.SetValue(parameterName, (Int64)value);
                        break;
                    case RegistryValueKind.Binary:
                        newSetting.SetValue(parameterName, (byte[])value);
                        break;
                    case RegistryValueKind.MultiString:
                        newSetting.SetValue(parameterName, (string[])value, typeOfKey);
                        break;
                }
                Gpo gpoTarget = _gpDomain.GetGpo(gpoName);
                RegistryPolicy registry = gpoTarget.User.Policy.GetRegistry(false);
                try
                {
                    ReadOnlyCollection<RegistryItem> items = gpoTarget.User.Policy.GetRegistry(false).Read(newSetting.Hive, keyPath);
                    foreach (RegistryItem item in items)
                    {
                        if (((RegistrySetting) item).ValueName == parameterName)
                        {
                            contains = true;
                        }
                    }
                    registry.Write((PolicyRegistrySetting) newSetting, !contains);
                    registry.Save(false);
                    return true;
                }
                catch (ArgumentException)
                {
                    registry.Write((PolicyRegistrySetting)newSetting, contains);
                    registry.Save(true);
                    return true;
                }
            }
            catch (Exception)
            {
                return false;
            }
        }
    
    0 讨论(0)
  • 2020-12-03 02:55

    Try using IGroupPolicyObject

    bool SetGroupPolicy(HKEY hKey, LPCTSTR subKey, LPCTSTR valueName, DWORD dwType, const BYTE* szkeyValue, DWORD dwkeyValue)
    {
        CoInitialize(NULL);
        HKEY ghKey, ghSubKey, hSubKey;
        LPDWORD flag = NULL;
        IGroupPolicyObject *pGPO = NULL;
        HRESULT hr = CoCreateInstance(CLSID_GroupPolicyObject, NULL, CLSCTX_ALL, IID_IGroupPolicyObject, (LPVOID*)&pGPO);
    
        if(!SUCCEEDED(hr))
        {
            MessageBox(NULL, L"Failed to initialize GPO", L"", S_OK);
        }
    
        if (RegCreateKeyEx(hKey, subKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &hSubKey, flag) != ERROR_SUCCESS)
        {
            return false;
            CoUninitialize();
        }
    
        if(dwType == REG_SZ)
        {
            if(RegSetValueEx(hSubKey, valueName, 0, dwType, szkeyValue, strlen((char*)szkeyValue) + 1) != ERROR_SUCCESS)
            {
                RegCloseKey(hSubKey);
                CoUninitialize();
                return false;
            }
        }
    
        else if(dwType == REG_DWORD)
        {
            if(RegSetValueEx(hSubKey, valueName, 0, dwType, (BYTE*)&dwkeyValue, sizeof(dwkeyValue)) != ERROR_SUCCESS)
            {
                RegCloseKey(hSubKey);
                CoUninitialize();
                return false;
            }
        }
    
        if(!SUCCEEDED(hr))
        {
            MessageBox(NULL, L"Failed to initialize GPO", L"", S_OK);
            CoUninitialize();
            return false;
        }
    
        if(pGPO->OpenLocalMachineGPO(GPO_OPEN_LOAD_REGISTRY) != S_OK)
        {
            MessageBox(NULL, L"Failed to get the GPO mapping", L"", S_OK);
            CoUninitialize();
            return false;
        }
    
        if(pGPO->GetRegistryKey(GPO_SECTION_USER,&ghKey) != S_OK)
        {
            MessageBox(NULL, L"Failed to get the root key", L"", S_OK);
            CoUninitialize();
            return false;
        }
    
        if(RegCreateKeyEx(ghKey, subKey, 0, NULL, REG_OPTION_NON_VOLATILE, KEY_WRITE, NULL, &ghSubKey, flag) != ERROR_SUCCESS)
        {
            RegCloseKey(ghKey);
            MessageBox(NULL, L"Cannot create key", L"", S_OK);
            CoUninitialize();
            return false;
        }
    
        if(dwType == REG_SZ)
        {
            if(RegSetValueEx(ghSubKey, valueName, 0, dwType, szkeyValue, strlen((char*)szkeyValue) + 1) != ERROR_SUCCESS)
            {
                RegCloseKey(ghKey);
                RegCloseKey(ghSubKey);
                MessageBox(NULL, L"Cannot create sub key", L"", S_OK);
                CoUninitialize();
                return false;
            }
        }
    
        else if(dwType == REG_DWORD)
        {
            if(RegSetValueEx(ghSubKey, valueName, 0, dwType, (BYTE*)&dwkeyValue, sizeof(dwkeyValue)) != ERROR_SUCCESS)
            {
                RegCloseKey(ghKey);
                RegCloseKey(ghSubKey);
                MessageBox(NULL, L"Cannot set value", L"", S_OK);
                CoUninitialize();
                return false;
            }
        }
    
        if(pGPO->Save(false, true, const_cast<GUID*>(&EXTENSION_GUID), const_cast<GUID*>(&CLSID_GPESnapIn)) != S_OK)
        {
            RegCloseKey(ghKey);
            RegCloseKey(ghSubKey);
            MessageBox(NULL, L"Save failed", L"", S_OK);
            CoUninitialize();
            return false;
        }
    
        pGPO->Release();
        RegCloseKey(ghKey);
        RegCloseKey(ghSubKey);
        CoUninitialize();
        return true;
    }
    

    You can call this function like this..

    // Remove the Log Off in start menu
    SetGroupPolicy(HKEY_CURRENT_USER,
        L"Software\\Microsoft\\Windows\\CurrentVersion\\Policies\\Explorer",
        L"StartMenuLogOff", REG_DWORD, NULL, 1);
    
    0 讨论(0)
提交回复
热议问题