Versuche dies:
get-WmiObject -class Win32_Share -computer dc1.krypted.com
Ich versuche, eine Liste der Ordner zu erhalten, die für eine Dateifreigabe freigegeben sind. Im Moment habe ich zwei Testordner:
\\MYPC\Test1 \\MYPC\Test2
Dies ist der Code, den ich im Moment habe:
$FileServer = Read-Host "Enter file server to search" $FolderList = Get-ChildItem -Path $FileServer Write-Host $FolderList
Aber das kommt mit "Kann den Weg nicht finden". Ich sehe Beispiele dafür, wie dies \\Server\Share
als Verzeichnis zu tun ist, aber ist es möglich, das nur zu durchsuchen \\Server
?
Versuche dies:
get-WmiObject -class Win32_Share -computer dc1.krypted.com
Es gibt nur eine Möglichkeit, Freigaben von der Befehlszeile aus aufzurufen, die ich kenne, und das ist mit net view
:
C:\Users\mark.henderson>net view \\enetsqnap01 Shared resources at \\enetsqnap01 Share name Type Used as Comment ------------------------------------------------------------------------------- Backups Disk CallRecordings Disk Download Disk System default share home Disk Home homes Disk System default share Installs Disk Justin Disk Copy of files from Justin laptop michael Disk Multimedia Disk System default share Network Recycle Bin 1 Disk [RAID5 Disk Volume: Drive 1 2 3 4] Public Disk System default share Qsync Disk Qsync Recordings Disk System default share Sales Disk Sales Documents SalesMechanix Disk Server2012 Disk Windows Server 2012 Install Media Usb Disk System default share VMWareTemplates Disk Web Disk System default share The command completed successfully.
Dies ist nicht besonders parsbar für sich allein, aber Sie können es in ein Array werfen, um die Daten Zeile für Zeile zu verarbeiten:
$sharedFolders = (NET.EXE VIEW \\enetsqnap01)
Sie haben jetzt ein Array und haben ab sofort $sharedFolders[7]
Ihre Freigaben. Sie könnten dann split
auf einem doppelten Leerzeichen stehen - unwahrscheinlich, dass es in einem Freigabenamen selbst angezeigt wird, und es sollte funktionieren, wenn Ihr Freigabename nicht sehr lang ist und nur ein Leerzeichen zwischen dem Freigabenamen und dem Typfeld übrig lässt:
$sharedFolders[7].split(' ')[0] Backups
Sie können diese mit Hilfe von ForEach und einer bedingten Logik verarbeiten. Es wäre nicht perfekt, aber es sollte für die meisten Anwendungsfälle funktionieren.
Der Einfachheit halber, um die Dateinamen einfach auf der Konsole auszugeben:
(net view \\enetsqnap01) | % { if($_.IndexOf(' Disk ') -gt 0){ $_.Split(' ')[0] } }
Wenn Sie die Freigaben des lokalen Computers suchen möchten, können Sie Folgendes tun Get-SmbShare
:
> Get-SmbShare Name ScopeName Path Description ---- --------- ---- ----------- ADMIN$ * C:\WINDOWS Remote Admin C$ * C:\ Default share
Die Antwort von Mark Henderson erweitern :
$Servers = ( Get-ADComputer -Filter { DNSHostName -Like '*' } | Select -Expand Name ) foreach ($Server in $Servers) { (net view $Server) | % { if($_.IndexOf(' Disk ') -gt 0){ $_.Split(' ')[0] } } | out-file C:\file_shares\$Server.txt }
Danke an Mark Henderson für seine Lösung . Ich habe eine Wrapper-Funktion hinzugefügt, um den Aufruf dieser Funktion für mehr PowerShell-freundlicher zu gestalten. Ich habe einen anderen Ansatz zum Aufteilen der Daten verwendet (komplexer, nicht besser); das kann je nach Präferenz leicht umgeschaltet werden.
clear-host function Get-SharedFolder { [CmdletBinding()] param( [Parameter(Mandatory = $true, ValueFromPipeline = $true)] [string]$ComputerName , [Parameter(Mandatory = $false)] [switch]$GetItem, [Parameter(Mandatory = $false)] [string[]]$ColumnHeadings = @('Share name','Type','Used as','Comment') #I suspect these differ depending on OS language? Therefore made customisable, [Parameter(Mandatory = $false)] [string]$ShareName = 'Share name' #tell us which of the properties relates to the share name #, #[Parameter(Mandatory = $false)] #[string[]]$Types = @('Disk') # again, likely differs with language. Also there may be other types to include? ) begin { [psobject[]]$Splitter = $ColumnHeadings | %{ $ColumnHeading = $_ $obj = new-object -TypeName PSObject -Property @{ Name = $ColumnHeading StartIndex = 0 Length = 0 } $obj | Add-Member -Name Initialise -MemberType ScriptMethod { param([string]$header) process { $_.StartIndex = $header.indexOf($_.Name) $_.Length = ($header -replace ".*($($_.Name)\s*).*",'$1').Length } } $obj | Add-Member -Name GetValue -MemberType ScriptMethod { param([string]$line) process { $line -replace ".{$($_.StartIndex)}(.{$($_.Length)}).*",'$1' } } $obj | Add-Member -Name Process -MemberType ScriptMethod { param([psobject]$obj,[string]$line) process { $obj | Add-Member -Name $_.Name -MemberType NoteProperty -Value ($_.GetValue($line)) } } $obj } } process { [string[]]$output = (NET.EXE VIEW $ComputerName) [string]$headers = $output[4] #find the data's heading row $output = $output[7..($output.Length-3)] #keep only the data rows $Splitter | %{$_.Initialise($headers)} foreach($line in $output) { [psobject]$result = new-object -TypeName PSObject -Property @ $Splitter | %{$_.Process($result,$line)} $result | Add-Member '_ShareNameColumnName' -MemberType NoteProperty -Value $ShareName $result | Add-Member 'Path' -MemberType ScriptProperty -Value {("\\\" -f $this.ComputerName,$this."$($this._ShareNameColumnName)")} $result | Add-Member 'Item' -MemberType ScriptProperty -Value $result | Add-Member -MemberType MemberSet -Name PSStandardMembers -Value ([System.Management.Automation.PSMemberInfo[]]@(New-Object System.Management.Automation.PSPropertySet(‘DefaultDisplayPropertySet’,[string[]](@('ComputerName','Path') + $ColumnHeadings)))) $result } } } [string[]]$myServers = 'myServer1','myServer2' #amend this line to get the servers you're interested in [psobject[]]$shares = $myServers | Get-SharedFolder write-host 'List of Shares' -ForegroundColor Cyan $shares | ft -AutoSize write-host 'Shares as Get-Item output' -ForegroundColor Cyan $shares | select -expand Item
Windows Resource Kit-Tool: rmtshare .
Führen Sie entweder eine ID mit Administratorberechtigung auf dem Remote-Server aus oder stellen Sie eine IPC $ -Verbindung zum Remote-Server her.
rmtshare \\servername
Unter Windows 8 oder höher und Windows Server 2012 oder höher können Sie Get-SmbShare vom SmbShare-Modul aus verwenden.