2012-02-17 15 views
0

このプロセスをテキストファイルに記録する必要があります.2つの問題があります。 1.テキストファイルにエラーを書き込む方法は?今、電子メールが送信されないときは、何も記録されません。 2.私は今、私はlog.txtという中でこれを持って、単一の行にpowershell - .txtファイルと1行にエラーを書き込む

を、時間、日付やイベントを記述する必要があります。

17. feb. 2012 10:47:34 
Chyba: .gpg neexistuje 
17. feb. 2012 10:57:28 
Test.gpg existuje. 

は、これは私のコードです:

function write-log{ 
param(
[string]$mytext, 
[string]$fgc 
) 
if(!$fgc){$fgc="Black"} 
write-host $mytext -foregroundcolor $fgc 
$myfile = "c:\gnupg\subor\log.txt" 
Get-Date | Out-File $myfile -append 
$mytext | Out-File $myfile -append 
} 

if(test-path "d:\vm\shared pre ws08R2+SQL05\SFRB\*.chk") { 
echo "Subor .chk existuje a jeho nazov je " 
get-childitem "d:\vm\shared pre ws08R2+SQL05\SFRB\*.chk" -Name 
$a = get-childitem "d:\vm\shared pre ws08R2+SQL05\SFRB\*" -include *.chk -name | Foreach-Object {$a -replace ".chk", ""} 

if(test-path d:\vm\"shared pre ws08R2+SQL05"\SFRB\$a.gpg) { 
    Write-Log $a".gpg existuje." Green 

    Write-Log "Presuvam do banky subor $a.gpg.." Green 

    Move-Item "d:\vm\shared pre ws08R2+SQL05\SFRB\$a.gpg" c:\gnupg\subor\$a.gpg 
    Write-Log "Presun ukonceny." Green 

    Write-Log "Presuvam do banky subor $a.chk.." Green 
    Move-Item "d:\vm\shared pre ws08R2+SQL05\SFRB\$a.chk" c:\gnupg\subor\$a.chk 
    Write-Log "Presun ukonceny. Subor je pripraveny na spracovanie." Green 

    Write-Log "Posielam notifikacne maily.." Green 
    $emailFrom = "[email protected]" 
    $emailTo = "[email protected]" 
    $subject = "subject" 
    $body = "subor presunuty" 
    $smtpServer = "87.244.217.54" 
    $smtp = new-object Net.Mail.SmtpClient($smtpServer) 
    $smtp.Send($emailFrom, $emailTo, $subject, $body) 
    # Write-Log "Maily odoslane." Green 

     } 
     else { 
       Write-Log " Chyba: $a.gpg neexistuje" Magenta 
     } 
} else { 
Write-log "V cielovom adresari neexistuje ziadny subor .chk." 
} 

ありがとうございました。

答えて

1
  1. パラメータ-ErrorAction Stopと作り付けのSend-MailMessageコマンドレットを使用してください。

  2. はピックアップし、すべてのエラーを処理するためにabout_try_catch_finallyを参照してください(この周りのtry-catchを使用してください。

    catchブロックで$_は、エラーメッセージになります(コンソールに表示されるように)、および(.NET)Exception(またはサブクラス)のインスタンス(私はそれがどんな診断の重要な一部であるとして、特にこのタイプを報告するには、以下の$_.Exception.GetType()を使用)であるException性質があります。

例えば中私が持っているスクリプト:

try { 
     $trans = (MakeSummaryMessage) + "`r`n`r`n" + $trans 
     Send-MailMessage -From $emailFrom ` 
         -To $emailTo ` 
         -SmtpServer $emailServer ` 
         -Subject $subject" ` 
         -Body $trans ` 
         -Encoding ([System.Text.Encoding]::UTF8) ` 
         -ErrorAction Stop 
     $emailSent = $true 
    } catch { 

     Write-EventLog -LogName $eventLog -Source $eventSource -EntryType "Error" ` 
      -EventId 100 -Message "Failed to send email: $($_.Exception.GetType()): $_" 
    } 
関連する問題