windows – 创建要禁用的计算机列表

我的任务是自动禁用/删除旧计算机.不幸的是,我发现我为此任务提供的数据有很多错误并且我在验证它时遇到了问题.这里的要求是计算机帐户必须存在,它不能是重复的,它不能是服务器操作系统,并且计算机的帐户密码在过去10天内不得重置.我已经能够单独验证所有这些,但当我尝试将验证合并到一个脚本中时,我失败了.具体来说,我无法通过重复数据步骤.
这是代码
$file = "D:\Transcripts\ADPCverify\" + (get-date -Format yyyymmdd-hhmmss) + ".txt"
start-transcript -LiteralPath $file 
$date = Get-Date
$computers = Get-Content D:\Content\ADPCverify\unverified.txt | sort-object -unique
$list =   Get-Content D:\Content\ADPCdisable\computers.txt 
$name = 'null'
ForEach($computer in $computers){
    $prevname = $name
    $name = (Get-ADComputer -Identity $computer -Server server).name
    $PCObject = Get-ADComputer -Identity $computer -Server server -Properties *
    $OS = $PCObject.OperatingSystem
                $pwdLastSet = [DateTime]::FromFiletime([Int64]::Parse($PCobject.pwdLastSet))
                $TimeSince = New-TimeSpan $pwdLastSet $date
    if($name -eq $prevname){
        Add-Content D:\Content\ADPCdisable\FailedComputers.txt $computer
        write-host "Machine " + $computer + " does not exist and has been added to the Failed computers list."
    }elseif($OS -contains 'Windows Server'){
         Add-Content D:\Content\ADPCdisable\FailedComputers.txt $computer
         write-host "Machine " + $computer + " has a server OS and will be added to the Failed computer list."
    }elseif($TimeSince.totaldays -lt 10){
         Add-Content D:\Content\ADPCdisable\FailedComputers.txt $computer
         write-host "Machine " + $computer + "'s password was reset " + $TimeSince.totaldays + "  days ago and has been added to the Failed computer list."
    }else{
         Add-Content D:\Content\ADPCdisable\Computers.txt $name
         write-host "Machine " + $name + " has been succesfully added to the computers to disable list."
    }
} 
Stop-Transcript

该脚本似乎无法通过第二个if语句.如果我需要提供更多信息或者我错过了一个括号,请告诉我.

$file = "D:\Transcripts\ADPCverify\" + (get-date -Format yyyymmdd-hhmmss) + ".txt"
start-transcript -LiteralPath $file 
$date = Get-Date
$computers = Get-Content D:\Content\ADPCverify\unverified.txt | sort-object -unique
$list =   Get-Content D:\Content\ADPCdisable\computers.txt 
$name = 'null'
$server = ''
ForEach($computer in $computers){
    Try{
        $PCObject = Get-ADComputer -Identity $computer -Server $server -Properties *
        $name = $PCObject.Name
        $OS = $PCObject.OperatingSystem
        $pwdLastSet = [DateTime]::FromFiletime([Int64]::Parse($PCobject.pwdLastSet)) 
        $TimeSince = New-TimeSpan $pwdLastSet $date
        if($OS.StartsWith('Windows Server')){
            Add-Content D:\Content\ADPCdisable\FailedComputers.txt $computer
            write-host "Machine "  $computer  " has a server OS and will be added to the Failed computer list."
        }elseif($TimeSince.TotalDays -lt 10){
            Add-Content D:\Content\ADPCdisable\FailedComputers.txt $computer
            write-host "Machine "  $computer  "'s password was reset " + $TimeSince.TotalDays + "  days ago and has been added to the Failed computer list."
        }else{
            Add-Content D:\Content\ADPCdisable\Computers.txt $name
            write-host "Machine "  $name  " has been succesfully added to the computers to disable list."
        }
        }
     Catch{
        Add-Content D:\Content\ADPCdisable\FailedComputers.txt $computer
        write-host "Machine "  $computer  " does not exist and has been added to the Failed computers list."
     }

} 
Stop-Transcript

这是最终结果.我使用try / catch选项来抑制错误.我的问题是与-contains比较.感谢您的帮助!

相关文章

Windows2012R2备用域控搭建 前置操作 域控主域控的主dns:自...
主域控角色迁移和夺取(转载) 转载自:http://yupeizhi.blo...
Windows2012R2 NTP时间同步 Windows2012R2里没有了internet时...
Windows注册表操作基础代码 Windows下对注册表进行操作使用的...
黑客常用WinAPI函数整理之前的博客写了很多关于Windows编程的...
一个简单的Windows Socket可复用框架说起网络编程,无非是建...