about_Requires
Impede que um script seja executado sem os elementos necessários.
A #Requires
instrução impede que um script seja executado, a menos que a versão, os módulos (e a versão) e os pré-requisitos de edição do PowerShell sejam atendidos. Se os pré-requisitos não forem atendidos, o PowerShell não executará o script nem fornecerá outros recursos de runtime, como preenchimento de tabulação.
#Requires -Version <N>[.<n>]
#Requires -Modules { <Module-Name> | <Hashtable> }
#Requires -PSEdition <PSEdition-Name>
#Requires -RunAsAdministrator
Para obter mais informações sobre a sintaxe, consulte ScriptRequirements.
Um script pode incluir mais de uma #Requires
instrução. As #Requires
instruções podem aparecer em qualquer linha em um script.
Colocar uma #Requires
instrução dentro de uma função não limita seu escopo. Todas as #Requires
instruções são sempre aplicadas globalmente e devem ser atendidas antes que o script possa ser executado.
Aviso
Mesmo que uma #Requires
instrução possa aparecer em qualquer linha em um script, sua posição em um script não afeta a sequência de sua aplicação. O estado global que a #Requires
instrução apresenta deve ser atendido antes da execução do script.
Exemplo:
Get-Module AzureRM.Netcore | Remove-Module
#Requires -Modules AzureRM.Netcore
Você pode pensar que o código acima não deve ser executado porque o módulo necessário foi removido antes da #Requires
instrução. No entanto, o #Requires
estado teve que ser atendido antes que o script pudesse ser executado. Em seguida, a primeira linha do script invalidou o estado necessário.
Importante
A -Assembly
sintaxe foi preterida. Não serve para nada. A sintaxe foi adicionada no PowerShell 5.1, mas o código de suporte nunca foi implementado. A sintaxe ainda é aceita para compatibilidade com versões anteriores.
Especifica o caminho para o arquivo DLL do assembly ou um nome de assembly do .NET. O parâmetro Assembly foi introduzido no PowerShell 5.0. Para obter mais informações sobre assemblies .NET, consulte Nomes de assembly.
Por exemplo:
#Requires -Assembly path\to\foo.dll
#Requires -Assembly "System.Management.Automation, Version=3.0.0.0,
Culture=neutral, PublicKeyToken=31bf3856ad364e35"
Especifica a versão mínima do PowerShell que o script exige. Insira um número de versão principal e um número de versão secundária opcional.
Por exemplo:
#Requires -Version 6.0
Especifica os módulos do PowerShell que o script exige. Insira o nome do módulo e um número de versão opcional.
Se os módulos necessários não estiverem na sessão atual, o PowerShell os importará. Se os módulos não puderem ser importados, o PowerShell gerará um erro de encerramento.
A #Requires
instrução não carrega definições de classe e enumeração no módulo. Use a using module
instrução no início do script para importar o módulo, incluindo as definições de classe e enumeração. Para obter mais informações, consulte about_Using.
Para cada módulo, digite o nome do módulo (<String>) ou uma tabela de hash. O valor pode ser uma combinação de strings e tabelas de hash. A tabela de hash tem as seguintes chaves.
ModuleName
- Obrigatório Especifica o nome do módulo.GUID
- Opcional Especifica o GUID do módulo.- Também é necessário especificar pelo menos uma das três chaves abaixo.
ModuleVersion
- Especifica uma versão mínima aceitável do módulo.MaximumVersion
- Especifica a versão máxima aceitável do módulo.RequiredVersion
- Especifica uma versão exata e necessária do módulo. Isso não pode ser usado com as outras chaves de versão.
Observação
RequiredVersion
foi adicionado no Windows PowerShell 5.0.
MaximumVersion
foi adicionado no Windows PowerShell 5.1.
Por exemplo:
Requer que AzureRM.Netcore
(versão 0.12.0
ou superior) esteja instalado.
#Requires -Modules @{ ModuleName="AzureRM.Netcore"; ModuleVersion="0.12.0" }
Requer que AzureRM.Netcore
(somente a versão 0.12.0
) esteja instalada.
#Requires -Modules @{ ModuleName="AzureRM.Netcore"; RequiredVersion="0.12.0" }
Requer que AzureRM.Netcore
(versão 0.12.0
ou inferior) esteja instalado.
#Requires -Modules @{ ModuleName="AzureRM.Netcore"; MaximumVersion="0.12.0" }
Requer que qualquer versão do AzureRM.Netcore
e PowerShellGet
esteja instalada.
#Requires -Modules AzureRM.Netcore, PowerShellGet
Ao usar a RequiredVersion
chave, verifique se a string de versão corresponde exatamente à string de versão necessária.
Get-Module AzureRM.Netcore -ListAvailable
Directory: /home/azureuser/.local/share/powershell/Modules
ModuleType Version Name PSEdition ExportedCommands
---------- ------- ---- --------- ----------------
Script 0.12.0 AzureRM.Netcore Core
O exemplo a seguir falha porque 0.12 não corresponde exatamente a 0.12.0.
#Requires -Modules @{ ModuleName="AzureRM.Netcore"; RequiredVersion="0.12" }
Especifica uma edição do PowerShell que o script exige. Os valores válidos são Core para PowerShell e Desktop para Windows PowerShell.
Por exemplo:
#Requires -PSEdition Core
Quando esse parâmetro switch é adicionado à sua #Requires
instrução, ele especifica que a sessão do PowerShell na qual você está executando o script deve ser iniciada com direitos de usuário elevados. O parâmetro RunAsAdministrator é ignorado em um sistema operacional não Windows. O parâmetro RunAsAdministrator foi introduzido no PowerShell 4.0.
Por exemplo:
#Requires -RunAsAdministrator
O script a seguir tem duas #Requires
instruções. Se os requisitos especificados em ambas as instruções não forem atendidos, o script não será executado. Cada #Requires
instrução deve ser o primeiro item em uma linha:
#Requires -Modules AzureRM.Netcore
#Requires -Version 6.0
Param
(
[parameter(Mandatory=$true)]
[String[]]
$Path
)
...
Comentários do PowerShell
O PowerShell é um projeto código aberto. Selecione um link para fornecer comentários: