Search code examples
powershellwindows-server-2008-r2

PowerShell says "execution of scripts is disabled on this system."


I am trying to run a cmd file that calls a PowerShell script from cmd.exe, but I am getting this error:

Management_Install.ps1 cannot be loaded because the execution of scripts is disabled on this system.

I ran this command:

Set-ExecutionPolicy -ExecutionPolicy Unrestricted

When I run Get-ExecutionPolicy from PowerShell, it returns Unrestricted.

Get-ExecutionPolicy

Output:

Unrestricted

cd "C:\Projects\Microsoft.Practices.ESB\Source\Samples\Management Portal\Install\Scripts" powershell .\Management_Install.ps1 1

WARNING: Running x86 PowerShell...

File C:\Projects\Microsoft.Practices.ESB\Source\Samples\Management Portal\Install\Scripts\Management_Install.ps1 cannot be loaded because the execution of scripts is disabled on this system. Please see "get-help about_signing" for more details.

At line:1 char:25

  • .\Management_Install.ps1 <<<< 1

    • CategoryInfo : NotSpecified: (:) [], PSSecurityException

    • FullyQualifiedErrorId : RuntimeException

C:\Projects\Microsoft.Practices.ESB\Source\Samples\Management Portal\Install\Scripts> PAUSE

Press any key to continue . . .


The system is Windows Server 2008 R2.

What am I doing wrong?


Solution

  • If you're using Windows Server 2008 R2 then there is an x64 and x86 version of PowerShell both of which have to have their execution policies set. Did you set the execution policy on both hosts?

    As an Administrator, you can set the execution policy by typing this into your PowerShell window:

    Set-ExecutionPolicy RemoteSigned
    

    For more information, see Using the Set-ExecutionPolicy Cmdlet.

    When you are done, you can set the policy back to its default value with:

    Set-ExecutionPolicy Restricted
    

    You may see an error:

    Access to the registry key
    'HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\PowerShell\1\ShellIds\Microsoft.PowerShell' is denied. 
    To change the execution policy for the default (LocalMachine) scope, 
      start Windows PowerShell with the "Run as administrator" option. 
    To change the execution policy for the current user, 
      run "Set-ExecutionPolicy -Scope CurrentUser".
    

    So you may need to run the command like this (as seen in comments):

    Set-ExecutionPolicy RemoteSigned -Scope CurrentUser