about_Requires
Krátký popis
Zabrání spuštění skriptu bez požadovaných prvků.
Dlouhý popis
Příkaz #Requires
zabraňuje spuštění skriptu, pokud nejsou splněny požadavky na moduly, moduly (a verze) PowerShellu nebo moduly snap-in (a verze) a edice. Pokud nejsou splněné požadavky, PowerShell nespustí skript ani neposkytuje jiné funkce modulu runtime, jako je například dokončování tabulátoru.
Syntaxe
#Requires -Version <N>[.<n>]
#Requires -PSSnapin <PSSnapin-Name> [-Version <N>[.<n>]]
#Requires -Modules { <Module-Name> | <Hashtable> }
#Requires -PSEdition <PSEdition-Name>
#Requires -ShellId <ShellId> -PSSnapin <PSSnapin-Name> [-Version <N>[.<n>]]
#Requires -RunAsAdministrator
Další informace o syntaxi najdete v tématu ScriptRequirements.
Pravidla pro použití
Skript může obsahovat více než jeden #Requires
příkaz. Příkazy #Requires
se můžou objevit na libovolném řádku skriptu.
#Requires
Umístění příkazu do funkce neomezuje jeho rozsah. Všechny #Requires
příkazy se vždy použijí globálně a musí být splněny před spuštěním skriptu.
Upozorňující
I když se #Requires
příkaz může objevit na libovolném řádku skriptu, jeho pozice ve skriptu nemá vliv na sekvenci aplikace. Globální stav, který #Requires
příkaz prezentuje, musí být splněn před spuštěním skriptu.
Příklad:
Get-Module AzureRM.Netcore | Remove-Module
#Requires -Modules AzureRM.Netcore
Možná si myslíte, že výše uvedený kód by se neměl spouštět, protože požadovaný modul byl před příkazem #Requires
odebrán. #Requires
Stav však musel být splněn před spuštěním skriptu. První řádek skriptu zneplatní požadovaný stav.
Parametry
-Assembly Assembly Assembly <path> | <. Specifikace sestavení NET>
Důležité
Syntaxe -Assembly
je zastaralá. Neslouží žádné funkci. Syntaxe byla přidána v PowerShellu 5.1, ale podpůrný kód nebyl nikdy implementován. Syntaxe je stále přijímána kvůli zpětné kompatibilitě.
Určuje cestu k souboru knihovny DLL sestavení nebo názvu sestavení .NET. Parametr Sestavení byl zaveden v PowerShellu 5.0. Další informace o sestaveních .NET naleznete v tématu Názvy sestavení.
Příklad:
#Requires -Assembly path\to\foo.dll
#Requires -Assembly "System.Management.Automation, Version=3.0.0.0,
Culture=neutral, PublicKeyToken=31bf3856ad364e35"
-Version <N>[.<n>]
Určuje minimální verzi PowerShellu, kterou skript vyžaduje. Zadejte číslo hlavní verze a volitelné číslo podverze.
Příklad:
#Requires -Version 5.1
-PSSnapin PSSnapin-Name <> [-Version <N>[.<n>]]
Určuje modul snap-in PowerShellu, který skript vyžaduje. Zadejte název modulu snap-in a volitelné číslo verze.
Příklad:
#Requires -PSSnapin DiskSnapin -Version 1.2
-Modules <Název> modulu | <Hashtable>
Určuje moduly PowerShellu, které skript vyžaduje. Zadejte název modulu a volitelné číslo verze.
Pokud požadované moduly nejsou v aktuální relaci, PowerShell je naimportuje. Pokud se moduly nedají importovat, PowerShell vyvolá ukončující chybu.
Příkaz #Requires
nenačítá definice tříd a výčtů v modulu. K importu modulu, včetně definic tříd a výčtů, použijte příkaz using module
na začátku skriptu. Další informace najdete v tématu about_Using.
Pro každý modul zadejte název modulu (<String>) nebo hashtable. Hodnota může být kombinací řetězců a hashovatelných tabulek. Hashtable obsahuje následující klíče.
ModuleName
- Povinný argument Určuje název modulu.GUID
- Volitelné určuje identifikátor GUID modulu.- Je také povinné zadat aspoň jeden ze tří následujících klíčů.
ModuleVersion
– Určuje minimální přijatelnou verzi modulu.MaximumVersion
– Určuje maximální přijatelnou verzi modulu.RequiredVersion
– Určuje přesnou požadovanou verzi modulu. Tuto možnost nelze použít s jinými klíči verze.
Poznámka:
RequiredVersion
byl přidán ve Windows PowerShellu 5.0.
MaximumVersion
byl přidán ve Windows PowerShellu 5.1.
Příklad:
Vyžaduje, aby Hyper-V
byla nainstalovaná (verze 1.1
nebo vyšší).
#Requires -Modules @{ ModuleName="Hyper-V"; ModuleVersion="1.1" }
Vyžaduje, aby Hyper-V
byla nainstalovaná (pouze verze 1.1
).
#Requires -Modules @{ ModuleName="Hyper-V"; RequiredVersion="1.1" }
Vyžaduje, aby Hyper-V
byla nainstalovaná (verze 1.1
nebo menší).
#Requires -Modules @{ ModuleName="Hyper-V"; MaximumVersion="1.1" }
Vyžaduje, aby byla nainstalována jakákoli verze PSScheduledJob
a PSWorkflow
.
#Requires -Modules PSWorkflow, PSScheduledJob
Při použití RequiredVersion
klíče se ujistěte, že řetězec verze přesně odpovídá řetězci verze, který chcete vyžadovat.
Get-Module Hyper-V
ModuleType Version Name ExportedCommands
---------- ------- ---- ------------------
Binary 2.0.0.0 hyper-v {Add-VMAssignableDevice, ...}
Následující příklad selže, protože 2.0.0 přesně neodpovídá 2.0.0.0.
#Requires -Modules @{ ModuleName="Hyper-V"; RequiredVersion="2.0.0" }
-PSEdition <PSEdition-Name>
Určuje edici PowerShellu, kterou skript vyžaduje. Platné hodnoty jsou Core pro PowerShell a Desktop pro Windows PowerShell.
Příklad:
#Requires -PSEdition Core
-ShellId
Určuje prostředí, které skript vyžaduje. Zadejte ID prostředí. Pokud používáte parametr ShellId , musíte zahrnout také parametr PSSnapin .
Aktuální ID prostředí najdete dotazem na automatickou $ShellId
proměnnou.
Příklad:
#Requires -ShellId MyLocalShell -PSSnapin Microsoft.PowerShell.Core
Poznámka:
Tento parametr je určený pro použití v mini shellech, které byly zastaralé.
-RunAsAdministrator
Když se tento parametr přepínače přidá do příkazu #Requires
, určuje, že relace PowerShellu, ve které skript spouštíte, musí být spuštěna se zvýšenými uživatelskými právy. Parametr RunAsAdministrator je ignorován v operačním systému, který není systémem Windows. Parametr RunAsAdministrator byl zaveden v PowerShellu 4.0.
Příklad:
#Requires -RunAsAdministrator
Příklady
Následující skript obsahuje dva #Requires
příkazy. Pokud nejsou splněny požadavky zadané v obou příkazech, skript se nespustí. Každý #Requires
příkaz musí být první položkou na řádku:
#Requires -Modules PSWorkflow
#Requires -Version 3
Param
(
[parameter(Mandatory=$true)]
[String[]]
$Path
)
...