Top-Themen

AppleEntwicklungHardwareInternetLinuxMicrosoftMultimediaNetzwerkeOff TopicSicherheitSonstige SystemeVirtualisierungWeiterbildungZusammenarbeit

Aktuelle Themen

Administrator.de FeedbackApache ServerAppleAssemblerAudioAusbildungAuslandBackupBasicBatch & ShellBenchmarksBibliotheken & ToolkitsBlogsCloud-DiensteClusterCMSCPU, RAM, MainboardsCSSC und C++DatenbankenDatenschutzDebianDigitiales FernsehenDNSDrucker und ScannerDSL, VDSLE-BooksE-BusinessE-MailEntwicklungErkennung und -AbwehrExchange ServerFestplatten, SSD, RaidFirewallFlatratesGoogle AndroidGrafikGrafikkarten & MonitoreGroupwareHardwareHosting & HousingHTMLHumor (lol)Hyper-VIconsIDE & EditorenInformationsdiensteInstallationInstant MessagingInternetInternet DomäneniOSISDN & AnaloganschlüsseiTunesJavaJavaScriptKiXtartKVMLAN, WAN, WirelessLinuxLinux DesktopLinux NetzwerkLinux ToolsLinux UserverwaltungLizenzierungMac OS XMicrosoftMicrosoft OfficeMikroTik RouterOSMonitoringMultimediaMultimedia & ZubehörNetzwerkeNetzwerkgrundlagenNetzwerkmanagementNetzwerkprotokolleNotebook & ZubehörNovell NetwareOff TopicOpenOffice, LibreOfficeOutlook & MailPapierkorbPascal und DelphiPeripheriegerätePerlPHPPythonRechtliche FragenRedHat, CentOS, FedoraRouter & RoutingSambaSAN, NAS, DASSchriftartenSchulung & TrainingSEOServerServer-HardwareSicherheitSicherheits-ToolsSicherheitsgrundlagenSolarisSonstige SystemeSoziale NetzwerkeSpeicherkartenStudentenjobs & PraktikumSuche ProjektpartnerSuseSwitche und HubsTipps & TricksTK-Netze & GeräteUbuntuUMTS, EDGE & GPRSUtilitiesVB for ApplicationsVerschlüsselung & ZertifikateVideo & StreamingViren und TrojanerVirtualisierungVisual StudioVmwareVoice over IPWebbrowserWebentwicklungWeiterbildungWindows 7Windows 8Windows 10Windows InstallationWindows MobileWindows NetzwerkWindows ServerWindows SystemdateienWindows ToolsWindows UpdateWindows UserverwaltungWindows VistaWindows XPXenserverXMLZusammenarbeit
GELÖST

Powershell - Logfile schreiben wenn Ordner erstellt

Frage Entwicklung Batch & Shell

Mitglied: Korbi1328

Korbi1328 (Level 1) - Jetzt verbinden

12.05.2011 um 12:51 Uhr, 5905 Aufrufe, 5 Kommentare

Hallo Zusammen,

in einem Script werden verschiedene Ordner erstellt und Registry-Keys angelegt, neben bei soll hierzu ein Logfile geschrieben werden.

New-Item "$env:ProgramFiles\NewFolder" -type directory

Jetzt soll abgefragt werden ob der Ordner erstellt wurde, wenn ja soll das im Logfile erscheinen, wenn nicht dann soll ein Error im Logfile erscheinen.

Schön wäre es wenn der Output von "verbose" im Logfile erscheinen würde.

Fällt jemanden dazu etwas ein?

Danke im Voraus!
Mitglied: Pemo11
12.05.2011 um 13:59 Uhr
Hallo User,

Ich würde das FileSystemWatcher-Objekt benutzen mit dem sich ein bestimmtes Verzeichnis überwachen lässt und das Event per Register-ObjectEvent registrieren. Über den Action-Parameter kann man einen Skriptblock angeben, der als Job ausgeführt wird, wenn das Event später eintritt.

Der Output von Verbose lässt sich leider nicht umleiten. Das Logfle schreiben geht ja per Write-EventLog ganz einfach (wenn die Source existiert, ansonsten muss sie mit New-Eventlog angelegt werden).

Hier ist ein kleines Skript, das einen Ordner anlegt und über ein Event eine Meldung ausgibt, dass der Ordner angelegt wurde.
01.
<# 
02.
 .Synopsis 
03.
 Anlegen von Ordnern überwachen 
04.
#> 
05.
 
06.
$OrdnerPfad = "C:\PsTestDir" 
07.
$OrdnerName = "Pemo" 
08.
if (Test-Path -Path $OrdnerPfad) 
09.
{ Remove-Item -Path $OrdnerPfad } 
10.
New-Item -Path $OrdnerPfad -ItemType Directory | Out-Null 
11.
 
12.
$Fsw = New-Object -TypeName System.IO.FileSystemWatcher 
13.
$Fsw.Path = $OrdnerPfad 
14.
$Fsw.EnableRaisingevents = $true 
15.
 
16.
# Event registrieren 
17.
Register-ObjectEvent -InputObject $Fsw -EventName "Created" -SourceIdentifier FswCreate ` 
18.
  -Action { $Global:OrdnerCreated = $($Event.SourceArgs[1].FullPath);[System.Windows.Forms.MessageBox]::Show("Ordner $OrdnerCreated wurde angelegt.") } | Out-Null 
19.
   
20.
 
21.
# Ordner anlegen - Verbose-Ausgabe kann nicht umgeleitet werden 
22.
$FolderCreated = New-Item -Path "$OrdnerPfad\$OrdnerName" -ItemType Directory  | Select -Exp FullName 
23.
$FolderCreated 
24.
$OrdnerCreated 
25.
 
26.
$Fsw.EnableRaisingEvents = $false 
27.
Unregister-Event -SourceIdentifier FswCreate 
28.
Get-Job -Name FswCreate -ErrorAction SilentlyContinue | Stop-Job -PassThru | Remove-Job -Force 
Ein wenig einfacher wäre natürlich, bei New-Item ein -ErrorAction = SilentlyContinue zu setzen und danach $? abzufragen. Der Event-Ansatz hat den Vorteil, dass dies nicht nach jedem Ordneranlegen geschehen muss.

Auf alle Fälle lässt sich daraus etwas machen.

Viele Grüße,
Pemo
[Edit Biber] Code-Formatierung [/Edit]
Bitte warten ..
Mitglied: Korbi1328
12.05.2011 um 15:39 Uhr
Danke für die Antwort erstmal!

Bei deinem Beispiel-Script wird ja in einer Message Box ausgeben, wie kann ich in einem Textfile ausgeben?

Außerdem noch eine kurze Frage: Um mehrere Ordner anzulegen muss ich dazu nur den ersten Block kopieren, oder?

$OrdnerPfad = "C:\PsTestDir"
$OrdnerName = "Pemo"
if (Test-Path -Path $OrdnerPfad)
{ Remove-Item -Path $OrdnerPfad }
New-Item -Path $OrdnerPfad -ItemType Directory | Out-Null

Gruß Korbi
Bitte warten ..
Mitglied: Pemo11
12.05.2011 um 18:44 Uhr
Hallo Korbi,

Ja, die Messagebox dient nur zur Veranschaulichung - damit lässt sich feststellen, dass überhaupt etwas passiert. Der Teil muss wieder raus.
Um mehrere Ordner anzulegen würde ich die Namen eventuell zu einer Variablen zusammenfassen:

Hier ist ein kleines Skript, das ein paar Ordner anlegt und pro angelegtem Ordner eine Meldung in das Application-Log schreibt mit dem Ordnerpfad als Message, Die Quelle ist OrdnerTest.
01.
<# 
02.
 .Synopsis 
03.
 Anlegen von Ordnern überwachen 
04.
#> 
05.
 
06.
$OrdnerPfad = "C:\PsTestDir" 
07.
 
08.
if (Test-Path -Path $OrdnerPfad) 
09.
{ Remove-Item -Path $OrdnerPfad } 
10.
New-Item -Path $OrdnerPfad -ItemType Directory | Out-Null 
11.
 
12.
$Fsw = New-Object -TypeName System.IO.FileSystemWatcher 
13.
$Fsw.Path = $OrdnerPfad 
14.
$Fsw.EnableRaisingevents = $true 
15.
 
16.
# Event-Quelle anlegen 
17.
New-EventLog -LogName Application -Source OrdnerTest -ErrorAction SilentlyContinue 
18.
 
19.
# Event registrieren 
20.
Register-ObjectEvent -InputObject $Fsw -EventName "Created" -SourceIdentifier FswCreate ` 
21.
  -Action { Write-EventLog -LogName Application -Source OrdnerTest -EventID 1000 -EntryType Information ` 
22.
   -Message "Ordner $($Event.SourceArgs[1].FullPath) wurde angelegt." } | Out-Null 
23.
 
24.
$OrdnerListe = "Ordner1", "Ordner2", "Ordner3" 
25.
   
26.
$OrdnerListe | Foreach-Object {  
27.
     New-Item -Path "$OrdnerPfad\$_" -ItemType Directory 
28.
29.
 
30.
$Fsw.EnableRaisingEvents = $false 
31.
Unregister-Event -SourceIdentifier FswCreate 
32.
Get-Job -Name FswCreate -ErrorAction SilentlyContinue | Stop-Job -PassThru | Remove-Job -Force 
Das sollte die Aufgabe erledigen.

Viele Grüße,
Pemo
[Edit Biber] Code-Formatierung [/Edit]
Bitte warten ..
Mitglied: Korbi1328
13.05.2011 um 10:03 Uhr
Hallo Pemo,

eine letzte Frage noch, mit dem FileSystemWatcher lässt sich ja nicht die Registry überwachen, wenn ich auf deine Weise Reg-Keys anlegen will. Gibt es hierzu etwas änliches?

Viele Grüße
Korbi
Bitte warten ..
Mitglied: Pemo11
13.05.2011 um 11:23 Uhr
Hallo Korbi,

Das geht auch, per WMI und einer WMI-Event-Klasse. Es ist sogar relativ einfach:
01.
<# 
02.
 .Synopsis 
03.
 Registry-Überwachung 
04.
#> 
05.
 
06.
$WQLQuery = @" 
07.
Select * From RegistryKeyChangeEvent Where Hive = 'HKEY_LOCAL_MACHINE' and KeyPath = 'Software\\Pemo' 
08.
"@ 
09.
 
10.
Register-WmiEvent -query $WQLQuery -SourceIdentifier RegEvent ` 
11.
 -Action { $RegPfad = [System.Windows.Forms.MessageBox]::Show("Neuer Subkey in $($Event.SourceEventArgs.NewEvent.KeyPath)") } 
12.
 
13.
#Unregister-Event -SourceIdentifier RegEvent
Der Name des neu angelegten Subkeys lässt sich meiner Meinung nach nicht abfragen (oder er versteckt sich in den Tiefen von dem Objekt, das über $Event angesprochen wird).

Das Ganze ist gut dokumentiert. Hier gibt es z.B. noch mehr dazu:

http://poshcode.org/2501

VIele Grüße,

Pemo
[Edit Biber] Code-Formatierung [/Edit]
Bitte warten ..
Ähnliche Inhalte
Windows Server
Powershell logfile nach Datei suchen (2)

Frage von krischeu zum Thema Windows Server ...

Batch & Shell
gelöst Powershell Ordner abgleichen (6)

Frage von banane31 zum Thema Batch & Shell ...

Outlook & Mail
Unter Outlook 2010 fehlen selbst erstellte Ordner (8)

Frage von Fitzel69 zum Thema Outlook & Mail ...

Batch & Shell
gelöst Batch, die Ordner erstellt und Berechtigungen setzt (12)

Frage von lordofremixes zum Thema Batch & Shell ...

Neue Wissensbeiträge
Windows Update

Microsoft Update KB4034664 verursacht Probleme mit Multimonitor-Systemen

(2)

Tipp von beidermachtvongreyscull zum Thema Windows Update ...

Viren und Trojaner

CNC-Fräsen von MECANUMERIC werden (ggf.) mit Viren, Trojanern, Würmern ausgeliefert

(4)

Erfahrungsbericht von anteNope zum Thema Viren und Trojaner ...

Windows 10

Windows 10: Erste Anmeldung Animation deaktivieren

(3)

Anleitung von alemanne21 zum Thema Windows 10 ...

Heiß diskutierte Inhalte
Netzwerkprotokolle
gelöst Leiten "dumme" Switches VLAN-Tags mit durch? (26)

Frage von coltseavers zum Thema Netzwerkprotokolle ...

Netzwerkgrundlagen
Kann auf Freigabe nicht Zugreifen (18)

Frage von leon123 zum Thema Netzwerkgrundlagen ...

Windows Server
gelöst Neues KB für W10 1607 und W2K16 wieder mal nicht im WSUS 3.0, hat das noch jemand? (16)

Frage von departure69 zum Thema Windows Server ...

Windows Server
DC virtualisieren + wie sichern (SingleDC-Environment) (12)

Frage von KMUlife zum Thema Windows Server ...