0

我有这个测试脚本来更改服务器列表上的管理员密码。如果无法 ping 服务器或找不到帐户等,我已将脚本设置为记录错误。但是除此之外,我还想捕获发生的任何其他错误并将这些错误添加到日志文件。我知道您可以使用“Try and Catch”进行错误处理,但到目前为止还没有任何运气。

有人会很好地展示如何做到这一点吗?

这是脚本

    $date = Get-Date
$user = "Administrator"
$newpwd = "MyPassword"

     $servers = gc C:\servers.txt

foreach ($server in $servers) 
{ 


  $ping = new-object System.Net.NetworkInformation.Ping

  $Reply = $null 
  $Reply = $ping.send($server)


  if($Reply.status -like 'Success')
    {

    $Admin=[adsi]("WinNT://" + $server + "/$user, user")

    if($?) 
      {
       $Admin.SetPassword($newpwd)

     if($?)

      {Add-Content -path C:\Audit\logs\servers-reset.csv -Value "$server,  Succsess the $user password was changed. , $date"}

      else
        {Add-Content -path C:\Audit\logs\servers-reset.csv -Value "$server, Error: FAILED to change the password. , $date"}
      }  
      else
      {
      Add-Content -path C:\Audit\logs\servers-reset.csv -Value "$server, Error: The $user user account was not found on the server. , $date"}
      }    
      else
      {
      Add-Content -path C:\Audit\logs\servers-reset.csv -Value "$server, Error: Ping FAILED could not connect. , $date"
      }
4

1 回答 1

2

如果您想在抛出异常后立即将异常写入日志,则可以使用陷阱。在你的脚本中添加这样的东西:

trap [Exception] {

    #Add message to log
    Add-Content -Path test.csv -Value "$server, $($_.Exception.Message), $(Get-Date)"

    #Continue script
    continue; 
}

这将记录所有异常(不是所有错误)。

如果您想要所有错误,您可以使用$Error. 它是一个数组列表,包含会话(脚本)期间的每个错误。第一项$Error[0]是最新的错误。但是,这不是直接适合 csv 文件而不对其进行格式化的东西。

于 2013-01-24T14:06:26.483 回答