about_Providers
Kurze Beschreibung
Beschreibt, wie PowerShell-Anbieter Zugriff auf Daten und Komponenten bieten, auf die sonst nicht einfach über die Befehlszeile zugegriffen werden kann. Die Daten werden in einem konsistenten Format dargestellt, das einem Dateisystemlaufwerk ähnelt.
Lange Beschreibung
PowerShell-Anbieter sind .NET-Programme, die Zugriff auf spezialisierte Datenspeicher bieten, um die Anzeige und Verwaltung zu erleichtern. Die Daten werden auf einem Laufwerk angezeigt, und Sie greifen auf die Daten in einem Pfad wie auf einer Festplatte zu. Sie können jedes der integrierten Cmdlets verwenden, die der Anbieter zum Verwalten der Daten im Anbieterlaufwerk unterstützt. Außerdem können Sie benutzerdefinierte Cmdlets verwenden, die speziell für die Daten entwickelt wurden.
Die Anbieter können den integrierten Cmdlets auch dynamische Parameter hinzufügen. Diese Parameter sind nur verfügbar, wenn Sie das Cmdlet mit den Anbieterdaten verwenden.
Integrierte Anbieter
PowerShell enthält eine Reihe integrierter Anbieter, die Zugriff auf verschiedene Objekttypen ermöglichen.
- Aliasanbieter
- Treiben-
Alias:
- Objekttypen - System.Management.Automation.AliasInfo
- Treiben-
- Zertifikatanbieter
- Treiben-
Cert:
- Objekttypen - Microsoft.PowerShell.Commands.X509StoreLocation, System.Security.Cryptography.X509Certificates.X509Certificate2
- Treiben-
- Umgebungsanbieter
- Treiben-
Env:
- Objekttypen – System.Collections.DictionaryEntry
- Treiben-
- FileSystem-Anbieter
- Laufwerk –
C:
und andere abhängig von der Hardware - Objekttypen – System.IO.FileInfo, System.IO.DirectoryInfo
- Laufwerk –
- Funktionsanbieter
- Treiben-
Function:
- Objekttypen - System.Management.Automation.FunctionInfo
- Treiben-
- Registrierungsanbieter
- Drive -
HKLM:
,HKCU:
- Objekttypen – Microsoft.Win32.RegistryKey
- Drive -
- Variabler Anbieter
- Treiben-
Variable:
- Objekttypen - System.Management.Automation.PSVariable
- Treiben-
- WSMan-Anbieter
- Treiben-
WSMan:
- Objekttypen - Microsoft.WSMan.Management.WSManConfigContainerElement
- Treiben-
Sie können auch eigene PowerShell-Anbieter erstellen und Anbieter installieren, die andere entwickeln. Geben Sie Folgendes ein, um die in Ihrer Sitzung verfügbaren Anbieter auflisten zu können:
Get-PSProvider
Hinweis
Die Anbieter "Certificate", "Registry" und "WSMan " sind nur auf der Windows-Plattform verfügbar.
Installieren und Entfernen von Anbietern
Anbieter werden in der Regel über PowerShell-Module installiert. Das Importieren des Moduls lädt den Anbieter in Ihre Sitzung. Sie können die integrierten Anbieter nicht deinstallieren. Sie können Anbieter deinstallieren, die von anderen Modulen geladen wurden.
Sie können einen Anbieter über das Remove-Module
Cmdlet aus der aktuellen Sitzung entladen. Dieses Cmdlet deinstalliert den Anbieter nicht, macht den Anbieter aber in der Sitzung nicht verfügbar.
Sie können auch das Remove-PSDrive
Cmdlet verwenden, um jedes Laufwerk aus der aktuellen Sitzung zu entfernen. Diese Daten auf dem Laufwerk sind nicht betroffen, aber das Laufwerk ist in dieser Sitzung nicht mehr verfügbar.
Anzeigen von Anbietern
Geben Sie Folgendes ein, um die PowerShell-Anbieter auf Ihrem Computer anzuzeigen:
Get-PSProvider
Die Ausgabe listet die integrierten Anbieter und die Anbieter auf, die Sie der Sitzung hinzugefügt haben.
Die Anbieter-Cmdlets
Die folgenden Cmdlets sind für die Arbeit mit den Daten konzipiert, die von einem beliebigen Anbieter verfügbar gemacht werden. Sie können dieselben Cmdlets auf die gleiche Weise verwenden, um die verschiedenen Datentypen zu verwalten, die Anbieter verfügbar machen. Nachdem Sie gelernt haben, die Daten eines Anbieters zu verwalten, können Sie dieselben Verfahren mit den Daten von jedem Anbieter verwenden.
Beispielsweise erstellt das New-Item
Cmdlet ein neues Element. Auf dem C:
Laufwerk, das vom FileSystem-Anbieter unterstützt wird, können New-Item
Sie eine neue Datei oder einen neuen Ordner erstellen. In den Laufwerken, die vom Registrierungsanbieter unterstützt werden, können New-Item
Sie einen neuen Registrierungsschlüssel erstellen. Auf dem Alias:
Laufwerk können New-Item
Sie einen neuen Alias erstellen.
Geben Sie detaillierte Informationen zu einem der folgenden Cmdlets ein:
Get-Help <cmdlet-name> -Detailed
ChildItem-Cmdlets
Inhalts-Cmdlets
Element-Cmdlets
ItemProperty-Cmdlets
- Clear-ItemProperty
- Copy-ItemProperty
- Get-ItemProperty
- Move-ItemProperty
- New-ItemProperty
- Remove-ItemProperty
- Rename-ItemProperty
- Set-ItemProperty
Cmdlets für Speicherorte
Pfad-Cmdlets
PSDrive-Cmdlets
PSProvider-Cmdlets
Anzeigen von Anbieterdaten
Der Hauptvorteil eines Anbieters besteht darin, dass er seine Daten auf vertraute und konsistente Weise verfügbar macht. Das Modell für die Datenpräsentation ist ein Dateisystemlaufwerk.
Mit dem Anbieter können Sie Elemente im Datenspeicher anzeigen, navigieren und ändern, als wären sie Daten in einem Dateisystem. Auf den Datenspeicher wird über den Namen des laufwerks zugegriffen, das unterstützt wird.
Das Laufwerk wird in der Standardanzeige des Cmdlets aufgeführt, Sie können jedoch Mithilfe des Get-PSProvider
Cmdlets Informationen zum Anbieterlaufwerk Get-PSDrive
abrufen. Um beispielsweise alle Eigenschaften der Funktion abzurufen: Laufwerk, geben Sie Folgendes ein:
Get-PSDrive Function | Format-List *
Sie können die Daten auf einem Anbieterlaufwerk genauso anzeigen und durchlaufen wie auf einem Dateisystemlaufwerk.
Verwenden Sie Get-Item
die Cmdlets, Get-ChildItem
um den Inhalt eines Anbieterlaufwerks anzuzeigen. Geben Sie den Laufwerknamen gefolgt von einem Doppelpunkt (:
) ein. Um beispielsweise den Inhalt des Alias:
Laufwerks anzuzeigen, geben Sie Folgendes ein:
Get-Item alias:
Sie können die Daten auf jedem Laufwerk von einem anderen Laufwerk anzeigen und verwalten, indem Sie den Laufwerknamen in den Pfad einschließen. Um beispielsweise den HKLM\Software
Registrierungsschlüssel auf dem HKLM:
Laufwerk von einem anderen Laufwerk anzuzeigen, geben Sie Folgendes ein:
Get-ChildItem HKLM:\SOFTWARE\
Verwenden Sie das Set-Location
Cmdlet, um das Laufwerk zu öffnen. Denken Sie beim Angeben des Laufwerkpfads an den Doppelpunkt. Wenn Sie beispielsweise Ihren Speicherort in das Stammverzeichnis des Cert:
Laufwerks ändern möchten, geben Sie Folgendes ein:
Set-Location cert:
Geben Sie dann Folgendes ein, um den Inhalt des Cert:
Laufwerks anzuzeigen:
Get-ChildItem
Navigieren durch hierarchische Daten
Sie können genauso wie eine Festplatte durch ein Anbieterlaufwerk navigieren. Wenn die Daten in einer Hierarchie von Elementen innerhalb von Elementen angeordnet sind, verwenden Sie einen umgekehrten Schrägstrich (\
), um ein untergeordnetes Element anzugeben. Verwenden Sie das folgende Format:
drive:\location\child-location\...
Wenn Sie beispielsweise Ihren Speicherort in den HKLM\Software
Registrierungsschlüssel ändern möchten, geben Sie einen Set-Location
Befehl ein, z. B.:
Set-Location HKLM:\SOFTWARE\
Wenn ein Element im vollqualifizierten Namen Leerzeichen enthält, müssen Sie den Namen in doppelte Anführungszeichen ("
) einschließen. Das folgende Beispiel zeigt einen vollqualifizierten Pfad, der Leerzeichen enthält.
"C:\Program Files\Internet Explorer\iexplore.exe"
Sie können auch relative Verweise auf Speicherorte verwenden. Ein Punkt (.
) stellt die aktuelle Position dar. Wenn Sie sich beispielsweise im HKLM:\Software\Microsoft
Registrierungsschlüssel befinden und die Registrierungsunterschlüssel im HKLM:\Software\Microsoft\PowerShell
Schlüssel auflisten möchten, geben Sie den folgenden Befehl ein:
Get-ChildItem .\PowerShell
Darüber hinaus bezieht sich double-dots (..
) direkt über Dem aktuellen Speicherort auf das Verzeichnis oder den Container. Sie können double-dots (..
) verwenden, um durch eine Anbieterhierarchie zu navigieren.
PS HKLM:\SYSTEM\CurrentControlSet\Services\LanmanServer\Parameters\> cd ..\..\LanmanWorkstation\Parameters
PS HKLM:\SYSTEM\CurrentControlSet\Services\LanmanWorkstation\Parameters>
Anbieter home
Anbieter haben auch einen Home-Standort . Dieser Speicherort wird von allen PSDrives
vom Anbieter unterstützt. Sie kann abgerufen werden, indem Sie die Home-Eigenschaft des Anbieters anzeigen.
Get-PSProvider | Format-Table Name, Home
Name Home
---- ----
Registry
Alias
Environment
FileSystem C:\Users\username
Function
Variable
Certificate
Der FileSystem-Anbieter ist der einzige Anbieter, der über einen Standardwert für Home verfügt. Es ist derselbe Wert wie $HOME
. Weitere Informationen finden Sie unter about_Automatic_Variables.
Sie können das Startverzeichnis für einen Anbieter für die aktuelle Sitzung mithilfe seiner Eigenschaft festlegen.
(Get-PSProvider FileSystem).Home = "C:\"
Das ~
Zeichen kann verwendet werden, um das Startverzeichnis des Anbieters darzustellen. Wenn der Anbieter nicht über einen Speicherort "Start " verfügt, wird ein Fehler angezeigt.
Cert:\> Set-Location ~
Set-Location : Home location for this provider isn't set. To set the home
location, call "(get-psprovider 'Certificate').Home = 'path'".
At line:1 char:1
+ Set-Location ~
+ ~~~~~~~~~~~~~~
+ CategoryInfo : InvalidOperation: (:) [Set-Location],
PSInvalidOperationException
...
Suchen dynamischer Parameter
Dynamische Parameter sind Cmdlet-Parameter, die einem Cmdlet von einem Anbieter hinzugefügt werden. Diese Parameter sind nur verfügbar, wenn das Cmdlet mit dem Anbieter verwendet wird, der sie hinzugefügt hat.
Beispielsweise fügt das Cert:
Laufwerk den CodeSigningCert-Parameter zu den Get-Item
Und-Cmdlets Get-ChildItem
hinzu. Sie können diesen Parameter nur verwenden, wenn Sie diesen Parameter verwenden oder Get-ChildItem
im Cert:
Laufwerk verwendenGet-Item
.
Eine Liste der dynamischen Parameter, die ein Anbieter unterstützt, finden Sie in der Hilfedatei für den Anbieter. Typ:
Get-Help <provider-name>
Zum Beispiel:
Get-Help certificate
Informationen zu Anbietern
Obwohl alle Anbieterdaten in Laufwerken angezeigt werden und Sie dieselben Methoden verwenden, um sie zu durchlaufen, wird die Ähnlichkeit dort beendet. Die Vom Anbieter verfügbar gemachten Datenspeicher können so vielfältig sein wie Active Directory-Speicherorte und Microsoft Exchange Server-Postfächer.
Geben Sie Folgendes ein, um Informationen zu einzelnen PowerShell-Anbietern zu erfahren:
Get-Help <ProviderName>
Zum Beispiel:
Get-Help registry
Geben Sie eine Liste der Hilfethemen zu den Anbietern ein:
Get-Help * -Category Provider