2

我已经测试了以下 PowerShell 注册表设置,并且设置正确。有人可以告诉我为远程计算机执行此操作的方法吗?

New-Item -itemType String HKLM:\SYSTEM\CurrentControlSet\Services\SNMP\Parameters\TrapConfiguration\Server0ps -Value "MY.DOMAIN.COM"
New-ItemProperty HKLM:\SYSTEM\CurrentControlSet\Services\SNMP\Parameters\PermittedManagers -Name 1 -Value "whatever" 
Set-ItemProperty HKLM:\SYSTEM\CurrentControlSet\Services\SNMP\Parameters\ValidCommunities -Name "Hello" -Value 4
Set-ItemProperty HKLM:\SYSTEM\CurrentControlSet\Services\SNMP\Parameters\ValidCommunities -Name "There" -Value 8
4

3 回答 3

4

以此为例:

$reg = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey('LocalMachine', $computername ) 
        $regKey= $reg.OpenSubKey("SOFTWARE\\Microsoft\\Windows\\CurrentVersion\\Run",$true) 
        $regKey.SetValue("New_Valuename_String","New_Valuedata",[Microsoft.Win32.RegistryValueKind]::String) 

要创建新密钥,您需要使用 cmdlet 的 powershell 远程invoke-command处理new-item

于 2013-09-19T13:59:52.477 回答
2

您可能需要检查PSRemoteRegistry PowerShell 模块及其 PowerShell 3.0 版本(支持 x86.x64,http ://psrr.codeplex.com/ )。

于 2013-09-19T14:10:37.703 回答
0

如果你只想删除一个键

$exchangeServers = @("xxxxx");
$hive = [Microsoft.Win32.RegistryHive]::LocalMachine;
$key = "SYSTEM\CurrentControlSet\Control\Lsa";

foreach ($exchangeServer in $exchangeServers)
{
    $regBaseKey = [Microsoft.Win32.RegistryKey]::OpenRemoteBaseKey($hive, $exchangeServer.ToString());
    $regKeys = $regBaseKey.OpenSubKey($key,$true);
    $beforeVal = $regKeys.GetValue("DisableLoopbackCheck");
    Write-Host $exchangeServer " - " $beforeVal;
    $regKeys.DeleteValue("DisableLoopbackCheck"); # a try catch can be placed here if there is a concern the key won't exist
    $keyNames = $regKeys.GetSubKeyNames();
    $afterVal = $regKeys.GetValue("DisableLoopbackCheck");
    if ($afterVal -eq $null)
    {
        Write-Host $exchangeServer " - deleted" -ForegroundColor DarkGreen;
    }
    else
    {
        Write-Host $exchangeServer " - " $afterVal -ForegroundColor Red;
    }
    Write-Host " ";
}
于 2018-11-13T20:14:07.873 回答