mvp (most windows les fondamentaux du langage...concrets d’utilisation, et de découvrir...

24
2 e édition PowerShell Core et Windows PowerShell Les fondamentaux du langage Robin LEMESLE Arnaud PETITJEAN

Upload: others

Post on 22-May-2020

2 views

Category:

Documents


0 download

TRANSCRIPT

Page 1: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

Pow

erS

hell

Les

fond

amen

taux

du

lang

age

ISB

N :

978-

2-40

9-01

328-

7

PowerShell Core et Windows PowerShell - Les fondamentaux du langageCe livre sur les fondamentaux de Windows PowerShell (toutes versions) et de PowerShell Core (versions multiplateforme et Open Source) a été écrit par les fondateurs de la communauté Power-Shell francophone (www.powershell-scripting.com). Il s’adresse aux professionnels de l’informatique désireux de s’initier aux techniques du scripting. Ce livre propose une approche progressive et didactique afin que les vrais débutants, c’est-à-dire ceux n’ayant jamais prati-qué PowerShell, puissent démarrer un apprentissage en douceur et acquérir de solides bases qui leur permettront de devenir autonomes. Les « faux débutants » y trouveront également leur compte car ils pour-ront parfaire leurs connaissances à travers les nombreuses bonnes pratiques que les auteurs ont pris soin de distiller au fil des chapitres.

Ce livre traite des bases du langage et n’est donc pas dépendant d’une version particulière de PowerShell. Lorsqu’il existe des diffé-rences d’implémentation, celles-ci sont mises en lumière et explici-tées afin que les scripts puissent être portables et retro-compatibles si nécessaire.

À travers les neuf premiers chapitres, le lecteur découvrira les notions essentielles pour bien démarrer telles que : la manipulation des objets, les types de variables, les opérateurs, les tableaux, les boucles et structures conditionnelles, les fonctions, les profils, etc. Ensuite, le chapitre sur les snapins, les modules et l’accès à la PowerShell Gallery expliquera comment enrichir PowerShell avec des commandes supplémentaires. Un chapitre conséquent traite de la gestion des erreurs et du débogage. Celui-ci donnera au lec-teur les bonnes techniques ainsi que les trucs et astuces à connaître pour apporter de la robustesse à ses scripts. La sécurité étant une préoccupation permanente, elle est détaillée dans un chapitre dédié. Le chapitre sur le framework .NET et .NET Core montrera que les capacités de PowerShell sont pratiquement illimitées. Un important chapitre est consacré aux technologies dites de remoting qui auto-risent l’exécution de commandes et de scripts PowerShell à distance : celui-ci précisera comment bien aborder ces technologies notamment sur l’aspect du paramétrage (tant sur WinRM que sur SSH) et sur les pièges à éviter (rebond, etc.).

Enfin, les derniers chapitres permettront au lecteur de mettre en œuvre PowerShell dans le monde de l’entreprise à l’aide de nombreux cas concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants du marché.

Des éléments complémentaires sont en téléchargement sur le site www.editions-eni.fr et sur le site de la communauté PowerShell fran-cophone : PowerShell-Scripting.com.

Téléchargementwww.editions-eni.fr.fr

Sur www.editions-eni.fr :b Tous les scripts proposés dans le livre. 39 €

Pour plus d’informations :

2e édition

Nouvelle édition

PowerShell Core et Windows PowerShellLes fondamentaux du langage

Robin LEMESLE

Arnaud PETITJEAN

Arnaud PETITJEAN est Ingénieur Système DevOps spécialiste en infrastructures Microsoft au sein d’une grande entreprise française de recherche. Pour son expertise et ses nombreuses contributions communautaires, Microsoft lui délivre le titre de MVP (Most

Valuable Professional) Cloud and Datacenter Management depuis l’année 2007. Il est à ce titre en relation directe avec l’équipe PowerShell chez Microsoft Corp. à Redmond.

Robin LEMESLE est Ingénieur Système, Expert en virtualisation et scripting sur les environne-ments Windows Server, au sein de la Française des Jeux.

Arnaud et Robin sont les co-fon-dateurs de la communauté PowerShell francophone (www.powershell-scripting.com). IT Pros confirmés, ils travaillent au quotidien dans de vastes environ-nements distribués et partagent volontiers tout au long de ces pages leur riche expérience terrain et leurs connaissances expertes sur PowerShell.

Avant-propos • Introduction • À la découverte de PowerShell • Manipulation des objets • Variables et types de données • Opérateurs • Tableaux • Boucles et conditions • Fonctions et scripts • Ges-tion des fichiers et des dates • Profils PowerShell • Snapins, modules et PowerShell Gallery • Gestion des erreurs et débogage • Sécurité • Framework .NET et .NET Core • CMI / WMI • Exécution à dis-tance • Études de cas • Ressources complémen-taires • Conclusion • Annexes

Les chapitres du livre

Page 2: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

1Table des matières

Avant-propos1. À propos de PowerShell. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19

2. À propos de cet ouvrage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20

3. À propos des auteurs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21

Introduction1. Pourquoi utiliser les scripts ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23

2. Historique des langages de script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24

3. Intérêt des scripts par rapport aux langages de programmation . . . . . . . . . 27

4. Pour résumer… . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27

Chapitre 1

À la découverte de PowerShell1. Présentation de PowerShell. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29

2. Historique des versions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30

3. Plateformes supportées . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333.1 Plateformes clientes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 333.2 Plateformes serveur. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34

4. Prise en main . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 354.1 Console Windows PowerShell classique . . . . . . . . . . . . . . . . . . . . . . . . 35

4.1.1 Démarrage de la console . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 354.1.2 Découverte de la console . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36

4.2 L'environnement d'écriture de scripts intégré (ISE) . . . . . . . . . . . . . . . 394.3 Visual Studio Code . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43

5. Une transition en douceur avec le passé . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47

Les éléments à télécharger sont disponibles à l'adresse suivante : http://www.editions-eni.fr 

Saisissez la référence ENI de l'ouvrage EI2CPOWFOL dans la zone de recherche et validez. Cliquez sur le titre du livre puis sur le bouton de téléchargement.

lcroise
Tampon
Page 3: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

2Windows PowerShell - Les fondamentaux du langage

PowerShell Core

6. Système d’aide intégré . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 496.1 Mise à jour des fichiers d’aide. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 506.2 Configuration du système d’aide en entreprise . . . . . . . . . . . . . . . . . . 51

6.2.1 Dépôt de l’aide sur un partage réseau . . . . . . . . . . . . . . . . . . . . . 526.2.2 Mise à jour de l’aide à partir d’un partage réseau. . . . . . . . . . . . 536.2.3 Forcer Update-Help à utiliser le dépôt . . . . . . . . . . . . . . . . . . . . 53

7. Commandes de base . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547.1 Constitution des commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 547.2 Get-Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 557.3 Get-Help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 58

7.3.1 Aide sur les commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 587.3.2 Aide conceptuelle . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61

7.4 Get-Member . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62

8. Gestion des répertoires et des fichiers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 648.1 Get-ChildItem (alias : gci, ls, dir) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 668.2 Set-Location (alias : sl, cd, chdir) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 698.3 Get-Location (alias : gl, pwd) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 698.4 New-Item (alias : ni, md) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 70

8.4.1 Création d'un répertoire. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 708.4.2 Création d'un fichier . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71

8.5 Remove-Item (alias : ri, rm, rmdir, rd, erase, del) . . . . . . . . . . . . . . . . . 718.6 Move-Item (alias : mi, move, mv) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72

8.6.1 Déplacement de fichiers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 728.6.2 Déplacement de répertoires. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72

8.7 Rename-Item (alias : ren, rni) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 738.7.1 Renommer un fichier . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 738.7.2 Renommer un dossier . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73

8.8 Copy-Item (alias : cpi, cp, copy) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74

9. Fournisseurs PowerShell . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74

Page 4: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

3Table des matières

Chapitre 2

Manipulation des objets1. Qu’est-ce que la notion d’objets ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79

2. Manipulation des objets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 812.1 Les collections . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 812.2 Différences de comportement entre versions de PowerShell . . . . . . . 85

2.2.1 Collections d’objets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 852.2.2 Expansion automatique des propriétés des éléments

d’une collection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 862.2.3 Where-Object et Foreach-Object simplifiés . . . . . . . . . . . . . . . . 87

2.3 Sélection/récupération des résultats . . . . . . . . . . . . . . . . . . . . . . . . . . . 882.3.1 Récupération des n premiers objets . . . . . . . . . . . . . . . . . . . . . . 892.3.2 Récupération des n derniers objets . . . . . . . . . . . . . . . . . . . . . . . 892.3.3 Récupération des objets uniques . . . . . . . . . . . . . . . . . . . . . . . . 902.3.4 Récupération d’une propriété particulière . . . . . . . . . . . . . . . . . 902.3.5 Sélection d’objets d'un tableau basée sur leur valeur d'index . . 922.3.6 Examen de tous les objets d’une collection . . . . . . . . . . . . . . . . 932.3.7 Regroupement d’objets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 942.3.8 Tri des objets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 962.3.9 Comptage/mesure des objets . . . . . . . . . . . . . . . . . . . . . . . . . . . 982.3.10 Comparaison d’objets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 100

2.4 Filtrer les objets. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101

3. Formatage des objets pour l'affichage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1033.1 Format-List . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104

3.1.1 Affichage sélectif des propriétés d'un objet . . . . . . . . . . . . . . . 1053.1.2 Affichage de toutes les propriétés disponibles d'un objet . . . . 106

3.2 Format-Table . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1083.2.1 Taille automatique d'un tableau. . . . . . . . . . . . . . . . . . . . . . . . 110

4. Création d'objets personnalisés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1114.1 Transformation d’un objet existant . . . . . . . . . . . . . . . . . . . . . . . . . . 1114.2 Création d’un objet à partir de rien . . . . . . . . . . . . . . . . . . . . . . . . . . . 1144.3 Ajout de membres. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 115

4.3.1 Ajout d’une propriété . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1154.3.2 Ajout d’une méthode. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117

4.4 Création d’une collection d’objets personnalisés . . . . . . . . . . . . . . . . 117

Page 5: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

4Windows PowerShell - Les fondamentaux du langage

PowerShell Core

Chapitre 3

Variables et types de données1. Les variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 119

1.1 Création et affectation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1191.2 Déterminer le type d’une variable . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1201.3 Accéder au contenu d’une variable . . . . . . . . . . . . . . . . . . . . . . . . . . . 120

2. Les constantes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 120

3. Types de données. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 121

4. Affectation manuelle de types et transtypage . . . . . . . . . . . . . . . . . . . . . . . 1224.1 Conversion d’un nombre décimal en hexadécimal . . . . . . . . . . . . . . . 1244.2 Conversion d’un nombre décimal en octal (base 8) . . . . . . . . . . . . . . 1244.3 Conversion d’un nombre décimal en binaire (base 2). . . . . . . . . . . . . 125

5. Rendre obligatoires la déclaration et l’initialisation des variables . . . . . . . 125

6. Variables prédéfinies . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1266.1 Variables automatiques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1266.2 Variables de préférence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 131

7. Portée des variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1357.1 Portée globale (global:) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1367.2 Portée locale (local:) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1377.3 Portée script (script:). . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1377.4 Portée privée (private:) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1387.5 Portée using (using:) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1397.6 Portée workflow (workflow:) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139

8. Quantificateurs d’octets . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 139

Chapitre 4

Opérateurs1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141

1.1 Opérateurs arithmétiques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 141

2. Opérateurs de comparaison. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1432.1 Comparaison sur des scalaires . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1432.2 Comparaison sur des tableaux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 144

3. Opérateurs de comparaison générique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145

Page 6: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

5Table des matières

4. Opérateur de comparaison des expressions régulières . . . . . . . . . . . . . . . . 1474.1 Opérations sur les scalaires . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1484.2 Opérations sur les tableaux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151

5. Opérateur de plage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152

6. Opérateurs d’appartenance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152

7. Opérateur de remplacement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1537.1 Remplacements à l’aide d’une expression régulière . . . . . . . . . . . . . . 1547.2 Remplacements appliqués sur un tableau. . . . . . . . . . . . . . . . . . . . . . 154

8. Opérateurs de type . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156

9. Opérateurs logiques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156

10. Opérateurs binaires . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 157

11. Opérateurs d’affectation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 159

12. Opérateurs de redirection . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 160

13. Opérateurs de fractionnement et de concaténation . . . . . . . . . . . . . . . . . . 164

14. Opérateur de format -f . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16514.1 Notions de base. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16514.2 Aller plus loin avec les formateurs de chaîne . . . . . . . . . . . . . . . . . . . 166

15. Récapitulatif sur les opérateurs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167

Chapitre 5

Tableaux1. Introduction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 171

2. Tableaux à une dimension . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1712.1 Initialiser un tableau vide. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1722.2 Initialiser un tableau avec des valeurs . . . . . . . . . . . . . . . . . . . . . . . . . 1732.3 Lire un tableau à une dimension . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1742.4 Concaténer deux tableaux . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1752.5 Ajouter un élément à un tableau . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1752.6 Modifier la valeur d’un élément. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1762.7 Supprimer un élément . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1762.8 Déterminer le nombre d’éléments d’un tableau . . . . . . . . . . . . . . . . . 1772.9 Convertir en chaîne le contenu d’un tableau . . . . . . . . . . . . . . . . . . . 177

3. Tableaux à plusieurs dimensions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 178

Page 7: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

6Windows PowerShell - Les fondamentaux du langage

PowerShell Core

4. Tableaux associatifs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1804.1 Tableaux associatifs standards. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 180

4.1.1 Déclarer un tableau associatif vide . . . . . . . . . . . . . . . . . . . . . . 1804.1.2 Initialiser un tableau associatif avec des données . . . . . . . . . . 1814.1.3 Ajout de données à un tableau associatif . . . . . . . . . . . . . . . . . 1824.1.4 Parcours d’un tableau associatif . . . . . . . . . . . . . . . . . . . . . . . . 182

4.2 Tableaux associatifs ordonnés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 183

Chapitre 6

Boucles et conditions1. Les boucles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 185

1.1 Boucle While . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1851.2 Boucle Do-While . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1861.3 Boucle Do-Until . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1861.4 Boucle For . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1871.5 Boucle Foreach. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 187

1.5.1 Première technique. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1881.5.2 Seconde technique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 189

2. Structure conditionnelle If, Else, ElseIf . . . . . . . . . . . . . . . . . . . . . . . . . . . . 190

3. Switch. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1933.1 Structure simple . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1933.2 Structure à base de sous-expressions . . . . . . . . . . . . . . . . . . . . . . . . . . 1943.3 Structure à base d’expressions régulières. . . . . . . . . . . . . . . . . . . . . . . 194

Chapitre 7

Fonctions et scripts1. Fonctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 195

1.1 Anatomie d’une fonction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1951.2 Utilisation des arguments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1961.3 Utilisation des paramètres . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1971.4 Retour de valeurs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 199

1.4.1 Retourner une valeur scalaire . . . . . . . . . . . . . . . . . . . . . . . . . . 1991.4.2 Retourner un objet. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200

Page 8: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

7Table des matières

1.5 Introduction aux « fonctions avancées » . . . . . . . . . . . . . . . . . . . . . . . 2021.5.1 Différences entre les fonctions classiques

et les fonctions avancées . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2031.5.2 Attributs de validation des paramètres . . . . . . . . . . . . . . . . . . 204

2. Scripts. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2072.1 Constitution d’un script. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2082.2 Commentaires. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2082.3 Exécution d’un script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2092.4 La directive #Requires . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2102.5 Prise de conscience de l’environnement d’exécution (contexte) . . . . 2112.6 Internationalisation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 214

3. DotSourcing. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 217

4. Aide intégrée aux scripts et fonctions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 218

Chapitre 8

Gestion des fichiers et des dates1. La gestion de fichiers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 223

1.1 Formats d’encodage des fichiers texte . . . . . . . . . . . . . . . . . . . . . . . . . 2241.2 Différences Windows PowerShell 5.x / PowerShell Core . . . . . . . . . 2271.3 Bonnes pratiques. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2281.4 Écriture de données dans un fichier. . . . . . . . . . . . . . . . . . . . . . . . . . . 228

1.4.1 Fichiers texte avec Out-File. . . . . . . . . . . . . . . . . . . . . . . . . . . . 2291.4.2 Redirection du flux standard . . . . . . . . . . . . . . . . . . . . . . . . . . 2311.4.3 Création de fichiers binaires avec Set-Content . . . . . . . . . . . . 232

1.5 Lecture de données avec Get-Content. . . . . . . . . . . . . . . . . . . . . . . . . 2371.6 Recherche de contenu dans un fichier avec Select-String . . . . . . . . . 2421.7 Gestion des fichiers CSV . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 248

1.7.1 Import/export de données . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2481.7.2 Conversion de données au format CSV . . . . . . . . . . . . . . . . . . 2521.7.3 Conversion de données à partir du format CSV . . . . . . . . . . . 253

1.8 Gestion des fichiers XML . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2551.8.1 Chargement d’un fichier XML . . . . . . . . . . . . . . . . . . . . . . . . . 2571.8.2 Gestion du contenu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2571.8.3 Export d’objets au format XML . . . . . . . . . . . . . . . . . . . . . . . . 2581.8.4 Sérialisation/désérialisation avec les commandes *-CliXML . 259

Page 9: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

8Windows PowerShell - Les fondamentaux du langage

PowerShell Core

1.9 Import/export de données au format JSON . . . . . . . . . . . . . . . . . . . . 2611.9.1 Export de données . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2611.9.2 Import de données . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 262

1.10 Export de données en tant que page HTML . . . . . . . . . . . . . . . . . . . . 2631.11 Export de données avec Out-GridView . . . . . . . . . . . . . . . . . . . . . . . . 268

2. Dates. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2702.1 Manipulation des objets DateTime . . . . . . . . . . . . . . . . . . . . . . . . . . . 2712.2 Formatage des dates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 273

2.2.1 Formats standards . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2752.2.2 Formats personnalisés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 276

2.3 Manipulation des dates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2792.3.1 Créer une date . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2792.3.2 Modifier une date. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2802.3.3 Comparer des dates . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2802.3.4 Calculer un intervalle entre deux dates . . . . . . . . . . . . . . . . . . 2812.3.5 Conversion d’une date exprimée en ticks. . . . . . . . . . . . . . . . . 282

Chapitre 9

Profils PowerShell1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285

2. Profils disponibles . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 286

3. Ordre d'application des profils . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 288

4. Création d’un profil . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 288

5. Personnalisation de l'environnement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2895.1 Modification du prompt. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 289

5.1.1 Un prompt haut en couleur. . . . . . . . . . . . . . . . . . . . . . . . . . . . 2915.1.2 Un prompt toujours à l'heure . . . . . . . . . . . . . . . . . . . . . . . . . . 291

5.2 Modification de la taille de la fenêtre . . . . . . . . . . . . . . . . . . . . . . . . . 2925.3 Modification des couleurs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2935.4 Modification du titre de la fenêtre. . . . . . . . . . . . . . . . . . . . . . . . . . . . 2945.5 Exemple de profil complet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 295

6. Exécuter PowerShell sans profil . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 297

Page 10: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

9Table des matières

Chapitre 10

Snap-ins, modules et PowerShell Gallery1. Introduction. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 299

2. Les snap-ins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2992.1 Lister les snap-ins installés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3002.2 Importer un snap-in . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3012.3 Lister les commandes d'un snap-in . . . . . . . . . . . . . . . . . . . . . . . . . . . 3022.4 Décharger un snap-in . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 302

3. Les modules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3033.1 Installer un module. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3033.2 Lister les modules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3053.3 Charger/importer un module. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3073.4 Préfixer les commandes d'un module . . . . . . . . . . . . . . . . . . . . . . . . . 3103.5 Lister les commandes d'un module . . . . . . . . . . . . . . . . . . . . . . . . . . . 3113.6 Tracer l’utilisation des modules. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3113.7 Décharger un module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 314

4. PowerShell Gallery . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3144.1 Qu’est-ce que c’est ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3144.2 Quid de la sécurité ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3154.3 Comment accéder à la galerie ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 316

4.3.1 Le site www.powershellgallery.com . . . . . . . . . . . . . . . . . . . . 3164.3.2 Le module PowerShellGet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319

4.4 Rechercher un module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3204.5 Sauvegarder un module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3244.6 Installer un module. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3254.7 Désinstaller un module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3264.8 Récupérer la liste des modules installés. . . . . . . . . . . . . . . . . . . . . . . . 3274.9 Mettre à jour un module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3294.10 Publier un module. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 330

4.10.1 Obtention de la clé d’API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3304.10.2 Création du manifeste de module . . . . . . . . . . . . . . . . . . . . . . 3314.10.3 Publication du module dans la galerie . . . . . . . . . . . . . . . . . . . 332

Page 11: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

10Windows PowerShell - Les fondamentaux du langage

PowerShell Core

Chapitre 11

Gestion des erreurs et débogage1. Introduction à la gestion des erreurs et au débogage. . . . . . . . . . . . . . . . . . 333

2. La gestion des erreurs. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 334

3. Les erreurs non critiques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3343.1 Variable de préférence : $ErrorActionPreference. . . . . . . . . . . . . . . . . 3353.2 Paramètre -ErrorAction et les paramètres communs . . . . . . . . . . . . . 3363.3 Consignation des erreurs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3393.4 Le type ErrorRecord . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3403.5 Redirection de l'affichage des messages d'erreur . . . . . . . . . . . . . . . . . 342

3.5.1 Redirection dans un fichier texte . . . . . . . . . . . . . . . . . . . . . . . 3433.5.2 Redirection dans une variable . . . . . . . . . . . . . . . . . . . . . . . . . . 3433.5.3 Redirection des erreurs vers $null . . . . . . . . . . . . . . . . . . . . . . . 344

3.6 Interception des erreurs non critiques . . . . . . . . . . . . . . . . . . . . . . . . . 3443.6.1 Cas général . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3443.6.2 Cas des exécutables externes. . . . . . . . . . . . . . . . . . . . . . . . . . . 344

4. Les erreurs critiques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3454.1 Interception des erreurs critiques avec Try-Catch-Finally . . . . . . . . . 3454.2 Déterminer le type des erreurs critiques . . . . . . . . . . . . . . . . . . . . . . . 3494.3 Générer des exceptions personnalisées . . . . . . . . . . . . . . . . . . . . . . . . 349

5. Le débogage . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3505.1 Affichage d’informations durant l’exécution . . . . . . . . . . . . . . . . . . . 351

5.1.1 Affichage de messages en mode verbose. . . . . . . . . . . . . . . . . . 3525.1.2 Affichage de messages en mode debug . . . . . . . . . . . . . . . . . . . 3535.1.3 Affichage de messages en mode warning . . . . . . . . . . . . . . . . . 3535.1.4 Affichage de messages d’informations . . . . . . . . . . . . . . . . . . . 354

5.2 Forcer la définition des variables . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3545.3 Exécution pas à pas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 356

5.3.1 Dans la console PowerShell classique . . . . . . . . . . . . . . . . . . . . 3565.3.2 Dans la console PowerShell ISE . . . . . . . . . . . . . . . . . . . . . . . . 362

5.4 Mode trace de Set-PSDebug . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3635.5 Trace-Command . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 366

Page 12: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

11Table des matières

Chapitre 12

Sécurité1. La sécurité : pour qui ? Pourquoi ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 373

2. Les risques liés au scripting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 373

3. Optimiser la sécurité PowerShell . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3743.1 La sécurité PowerShell par défaut . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3743.2 Les stratégies d'exécution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 375

3.2.1 Les différentes stratégies d'exécution . . . . . . . . . . . . . . . . . . . . 3753.2.2 Les étendues des stratégies d'exécution . . . . . . . . . . . . . . . . . . 3783.2.3 Identifier la stratégie d'exécution courante . . . . . . . . . . . . . . . 3783.2.4 Appliquer une stratégie d'exécution . . . . . . . . . . . . . . . . . . . . . 379

3.3 Scripts provenant d'Internet . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3813.4 Les Alternate Data Streams (ADS) . . . . . . . . . . . . . . . . . . . . . . . . . . . 383

3.4.1 Les origines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3833.4.2 Créer et lire les ADS. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3853.4.3 Observer et comprendre les ADS de vos fichiers .ps1 . . . . . . . 3863.4.4 Modifier le ZoneId ou comment transformer

un script distant en un script local . . . . . . . . . . . . . . . . . . . . . . 3873.5 Chaînes sécurisées. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 388

3.5.1 Sécuriser une chaîne . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3893.5.2 Lire une chaîne sécurisée . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 392

3.6 Chiffrement . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3933.6.1 Chiffrer une chaîne . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3973.6.2 Déchiffrer une chaîne . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 399

3.7 Gestion des credentials . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4003.8 Demander la saisie d’un mot de passe de façon sécurisée . . . . . . . . . 404

3.8.1 Utilisation de la commande Read-Host . . . . . . . . . . . . . . . . . . 4043.8.2 Utilisation de la commande Get-Credential . . . . . . . . . . . . . . 404

4. Signature des scripts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4054.1 Les signatures numériques . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4054.2 Les certificats. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 406

4.2.1 Acheter un certificat . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4064.2.2 Créer un certificat autosigné. . . . . . . . . . . . . . . . . . . . . . . . . . . 406

4.3 Signer votre premier script . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4144.4 Exécuter des scripts signés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 415

Page 13: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

12Windows PowerShell - Les fondamentaux du langage

PowerShell Core

5. Gérer les stratégies d'exécution de PowerShell via les stratégies de groupe . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 416

Chapitre 13

Framework .NET et .NET Core1. Introduction à .NET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 421

2. Le framework .NET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 422

3. .NET Core. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 424

4. PowerShell Core vs Windows PowerShell, à quel saint se vouer ? . . . . . . . 426

5. Utiliser des objets .NET avec PowerShell. . . . . . . . . . . . . . . . . . . . . . . . . . . 4265.1 Créer une instance de classe (Objet) . . . . . . . . . . . . . . . . . . . . . . . . . . 4305.2 Les assemblies . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4335.3 Charger une assembly. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4355.4 Lister les types contenus dans les assemblies . . . . . . . . . . . . . . . . . . . 436

6. Tirer parti de la puissance de .NET. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4386.1 Wake-on-LAN . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4386.2 Compresser/décompresser un dossier . . . . . . . . . . . . . . . . . . . . . . . . . 4396.3 Créer une bulle d’informations contextuelle (Balloon Tip) . . . . . . . . 442

Chapitre 14

CIM / WMI1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 445

2. Des standards, encore des standards, mais pour quoi faire ? . . . . . . . . . . . 4462.1 Qu'est-ce que WMI ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4472.2 Qu’est-ce que CIM ? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4472.3 CIM vs WMI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4482.4 Et concrètement, cela donne quoi ? . . . . . . . . . . . . . . . . . . . . . . . . . . . 448

2.4.1 Configuration de serveurs DELL via iDRAC . . . . . . . . . . . . . . 4482.4.2 Gestion de systèmes d’exploitation Linux depuis Windows. . 4492.4.3 Gestion de Windows Server 2012/R2 depuis Linux. . . . . . . . . 449

2.5 Difficultés à surmonter. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 449

3. Architecture générale et terminologie . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 450

Page 14: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

13Table des matières

4. Commandes de la famille CIM. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4524.1 Jeu de commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4524.2 Découverte des classes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 453

4.2.1 Lister toutes les classes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4544.2.2 Rechercher des classes contenant un mot particulier . . . . . . . 454

4.3 Découverte des membres d’une classe. . . . . . . . . . . . . . . . . . . . . . . . . 4564.3.1 Lister les membres d’une classe. . . . . . . . . . . . . . . . . . . . . . . . . 4564.3.2 Rechercher des membres d’une classe . . . . . . . . . . . . . . . . . . . 457

4.4 Récupération d’une ou plusieurs instances . . . . . . . . . . . . . . . . . . . . . 4584.5 Récupération d’une ou plusieurs instances avec filtre WQL/CQL . . 4594.6 Invocation d’une méthode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 461

5. Commandes de la famille WMI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4615.1 Recherche de classes et de membres . . . . . . . . . . . . . . . . . . . . . . . . . . 4635.2 Récupération d’une ou plusieurs instances . . . . . . . . . . . . . . . . . . . . . 464

6. Établissement de sessions avec des machines distantes . . . . . . . . . . . . . . . 4676.1 Commande New-CimSession . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4676.2 Commande New-CimSessionOption . . . . . . . . . . . . . . . . . . . . . . . . . 4686.3 Commande Get-CimSession . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4696.4 Commande Remove-CimSession . . . . . . . . . . . . . . . . . . . . . . . . . . . . 469

7. Monitoring de ressources avec la gestion des événements . . . . . . . . . . . . . 4697.1 Surveiller la création d'un processus local . . . . . . . . . . . . . . . . . . . . . . 4707.2 Surveiller la création d'un processus à distance . . . . . . . . . . . . . . . . . 4737.3 Surveiller l’espace disque d'un serveur distant . . . . . . . . . . . . . . . . . . 4757.4 Monitorer la suppression de fichiers . . . . . . . . . . . . . . . . . . . . . . . . . . 4767.5 Quelques explications complémentaires. . . . . . . . . . . . . . . . . . . . . . . 477

8. Gestion basée sur les URI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4778.1 Anatomie d’un URI . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4788.2 Jeux de commandes PowerShell . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 479

8.2.1 Jeu de commandes de la famille WSMan . . . . . . . . . . . . . . . . . 4808.2.2 Jeu de commandes de la famille CIM. . . . . . . . . . . . . . . . . . . . 481

8.3 Test de la bonne configuration d’un système. . . . . . . . . . . . . . . . . . . 4818.4 Envoi de requêtes CIM/WMI via un URI . . . . . . . . . . . . . . . . . . . . . . 482

8.4.1 Lister les services d'une machine distante . . . . . . . . . . . . . . . . 4828.4.2 Déterminer la date d'installation d'une machine distante . . . 483

Page 15: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

14Windows PowerShell - Les fondamentaux du langage

PowerShell Core

9. Boîte à outils graphiques pour l’exploration de la base CIM/WMI . . . . . . 4849.1 Testeur WMI (Wbemtest.exe) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4849.2 CIM Studio . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4859.3 SAPIEN WMI Explorer 2015 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 486

Chapitre 15

Exécution à distance1. Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 489

2. Communications à distance du Framework .NET . . . . . . . . . . . . . . . . . . . 4912.1 Prérequis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4922.2 Déterminer les commandes à distance du Framework .NET . . . . . . 4922.3 Jeu de commandes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4932.4 Envoi de commandes à distance. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 495

3. Communications à distance Windows PowerShell (WinRM) . . . . . . . . . . 4963.1 Authentification et chiffrement des communications . . . . . . . . . . . . 497

3.1.1 Dans un domaine Active Directory . . . . . . . . . . . . . . . . . . . . . 4973.1.2 Hors domaine Active Directory . . . . . . . . . . . . . . . . . . . . . . . . 4973.1.3 Modification du type d’authentification WinRM. . . . . . . . . . 498

3.2 Prérequis . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 4993.3 WinRM en environnement Active Directory . . . . . . . . . . . . . . . . . . . 500

3.3.1 Configuration manuelle. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5003.3.2 Activation du service WinRM. . . . . . . . . . . . . . . . . . . . . . . . . . 500

3.4 Configuration du service WinRM par GPO . . . . . . . . . . . . . . . . . . . . 5043.5 WinRM en environnement hors domaine. . . . . . . . . . . . . . . . . . . . . . 507

3.5.1 Configuration de la liste des machines de confiance (trusted hosts list) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 508

3.5.2 Désactivation de l’UAC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5093.5.3 Communiquer en HTTPS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 509

3.6 Problématique du "double saut" (notion de rebond). . . . . . . . . . . . . . 5133.6.1 CredSSP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5143.6.2 Double authentification . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5153.6.3 Point de terminaison délégué (mode RunAs). . . . . . . . . . . . . . 5173.6.4 Délégation Kerberos contrainte basée sur une ressource. . . . . 517

Page 16: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

15Table des matières

3.7 Gestion des configurations des sessions . . . . . . . . . . . . . . . . . . . . . . . 5193.7.1 Généralités . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5193.7.2 Configurations de session par défaut . . . . . . . . . . . . . . . . . . . . 5223.7.3 Modification des permissions . . . . . . . . . . . . . . . . . . . . . . . . . . 5233.7.4 Création d’une configuration de session personnalisée . . . . . 5253.7.5 Création d’une configuration de session déléguée (RunAs) . . 532

3.8 Sessions à distance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5353.9 Exécution de commandes à distance . . . . . . . . . . . . . . . . . . . . . . . . . . 5373.10 Sessions WinRM en mode déconnecté . . . . . . . . . . . . . . . . . . . . . . . . 5393.11 Exécution de scripts à distance . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5403.12 Copie de fichiers à travers une session de communication . . . . . . . . 5453.13 Ouverture d'une session interactive PowerShell à distance . . . . . . . . 545

3.13.1 Enter-PSSession . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5453.13.2 Powershell ISE (Integrated Scripting Environment) . . . . . . . . 548

3.14 Importation de commandes à distance . . . . . . . . . . . . . . . . . . . . . . . . 549

4. Communications à distance sur SSH (PowerShell Core uniquement) . . . 5524.1 Installation d’OpenSSH sur Windows . . . . . . . . . . . . . . . . . . . . . . . . 5524.2 Installation d’OpenSSH sur Linux . . . . . . . . . . . . . . . . . . . . . . . . . . . 5534.3 Exécution de commandes et scripts à distance. . . . . . . . . . . . . . . . . . 554

4.3.1 Établissement d’une session de communication . . . . . . . . . . . 5544.3.2 Envoi de commandes à distance . . . . . . . . . . . . . . . . . . . . . . . . 5554.3.3 Exécution d’un script à distance. . . . . . . . . . . . . . . . . . . . . . . . 556

4.4 Ouverture d’une session interactive à distance . . . . . . . . . . . . . . . . . 5584.5 Copie de fichiers à travers une session de communication . . . . . . . . 559

5. Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 559

Chapitre 16

Études de cas1. Trouver les comptes d'ordinateurs périmés dans AD DS . . . . . . . . . . . . . . 561

1.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5611.2 Difficultés à surmonter . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5621.3 Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 562

2. Lister les comptes d'utilisateurs inactifs dans AD DS. . . . . . . . . . . . . . . . . 5642.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5642.2 Solution : faire du ménage ! . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 564

Page 17: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

16Windows PowerShell - Les fondamentaux du langage

PowerShell Core

3. Changer le mot de passe Administrateur local à distance. . . . . . . . . . . . . . 5683.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5683.2 Difficultés à surmonter. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5693.3 Solution 1 : DCOM/RPC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5693.4 Solution 2 : WSMan/WinRM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 571

4. Surveiller l'arrivée d'un événement dans le journal . . . . . . . . . . . . . . . . . . . 5724.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5724.2 Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 572

5. Créer des comptes utilisateurs par lots. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5765.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5765.2 Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 576

6. Vérifier la version logicielle d'une application à distance . . . . . . . . . . . . . . 5796.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5796.2 Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 580

7. Mettre à jour la configuration réseau d'un ensemble de machines. . . . . . . 5827.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5827.2 Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5837.3 Test de la solution. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 585

8. Trouver les certificats expirés . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5898.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5898.2 Solution 1 : Job PowerShell planifié local . . . . . . . . . . . . . . . . . . . . . . 5898.3 Solution 2 : Interrogation depuis un point central . . . . . . . . . . . . . . . 593

9. Déléguer la gestion d’un serveur (quelques commandes seulement) . . . . . 5949.1 Problématique . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5949.2 Solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 595

Chapitre 17

Ressources complémentaires1. Ressources web . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 601

1.1 Sites Internet francophones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6011.1.1 PowerShell-Scripting.com :

la communauté PowerShell francophone. . . . . . . . . . . . . . . . . 6011.1.2 French PowerShell User Group . . . . . . . . . . . . . . . . . . . . . . . . . 603

Page 18: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

17Table des matières

1.2 Sites Internet anglophones. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6041.2.1 PowerShell Team Blog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6041.2.2 Dépôt GitHub PowerShell . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6051.2.3 PowerShell Magazine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 607

2. Outils tiers . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6082.1 PowerShell Plus . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6082.2 PowerShell Studio 2017 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6092.3 PowerGadget . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6102.4 PowerShell Universal Dashboard. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 610

Conclusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 613

Annexes1. Syntaxe des expressions régulières . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 615

2. Liste des verbes approuvés (Get-Verb) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 618

3. Liste des sources de trace (Get-TraceSource) . . . . . . . . . . . . . . . . . . . . . . . . 620

Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 621

Page 19: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

373

Chapitre 12

Sécurité

Sécurité1. La sécurité : pour qui ? Pourquoi ?

L'arrivée des réseaux locaux et d'Internet a changé beaucoup de choses dans la manièrede protéger son PC. Il ne suffit plus d'attacher son disque dur au radiateur et de fermerla porte du bureau le soir pour ne pas se faire voler ou pirater des données. Mainte-nant, protéger son poste de travail est devenu essentiel pour ne pas faire les fraisd'intrusions ou de malveillances.Mais alors contre qui se prémunir ? Eh bien, contre tout ce qui bouge… et même cequi ne bouge pas. En effet, que ce soient des programmes malveillants, des utilisateursmal intentionnés, voire des utilisateurs inexpérimentés, tous peuvent être considéréscomme une menace. C'est pour cela que vous devez verrouiller votre système en éta-blissant des règles de sécurité, en les appliquant et en vous assurant que les autres enfont tout autant.

2. Les risques liés au scripting

Vous allez vite deviner que ce qui fait la force du scripting en fait aussi sa faiblesse. Lafacilité avec laquelle vous pouvez tout faire, soit en cliquant sur un script, soit en l'exé-cutant depuis la fenêtre de commande, peut vous mettre dans l'embarras si vous nefaites pas attention.

lcroise
Tampon
Page 20: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

© E

dit

ions

EN

I -

All r

ights

rese

rved

374Windows PowerShell - Les fondamentaux du langage

PowerShell Core

Imaginez un script de logon qui dès l'ouverture de la session la verrouille aussitôt !Alors oui, c'est sympa entre copains, mais en entreprise, nous doutons que cela soit debon ton. Plus grave encore, un script provenant d'une personne mal intentionnée ouvraiment peu expérimentée en PowerShell (dans ce cas, nous vous conseillons de luiacheter un exemplaire de ce livre…) peut parfaitement vous bloquer des comptes uti-lisateurs dans Active Directory, vous formater un disque, vous faire rebooter sanscesse. Vous l'avez compris, un script peut tout faire. Car même si aujourd'hui desalertes sont remontées jusqu'à l'utilisateur pour le prévenir de l'exécution d'un script,elles ne sont pas capables de déterminer à l'avance si un script est nuisible au bon fonc-tionnement du système.Les risques liés au scripting se résument à une histoire de compromis : soit vous em-pêchez toute exécution de scripts, c'est-à-dire encourir le risque de vous « pourrir lavie » à faire et à refaire des tâches basiques et souvent ingrates, soit vous choisissezd'ouvrir votre système à PowerShell, en prenant soin de prendre les précautions quis'imposent.Mais ne vous laissez pas démoraliser car même si l'exécution de scripts vous expose àcertains problèmes de sécurité, PowerShell se dote de certains concepts qui font de luil’un des langages de script les plus sûrs. Il ne faut pas non plus oublier qu’en cas deproblème de sécurité, c’est l’image tout entière de Microsoft qui en pâtit…

3. Optimiser la sécurité PowerShell

3.1 La sécurité PowerShell par défaut

Vous l'avez compris, la sécurité est une chose très importante, surtout dans ledomaine du scripting. C'est pour cela que les créateurs de PowerShell ont inclus deuxrègles de sécurité par défaut.

Des fichiers ps1 associés au bloc-notes

L'extension « .ps1 » des scripts PowerShell, est par défaut associée à l'éditeur de textebloc-notes (ou Notepad). Ce procédé permet d'éviter de lancer des scripts potentielle-ment dangereux sur une mauvaise manipulation. Le bloc-notes est certes un éditeur unpeu classique, mais il a le double avantage d'être inoffensif et de ne pas bloquer l'exécu-tion d'un script lorsque celui-ci est ouvert avec l'éditeur. Vous remarquerez cependantque l’édition (clic droit + Modifier) des fichiers .ps1 est associée à l’éditeur ISE.

Remarque

Ce type de sécurité n'était pas mis en place avec les scripts VBS dont l'ouverture étaitdirectement associée au Windows Script Host.

Page 21: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

375SécuritéChapitre 12

Une stratégie d'exécution restreinte

La seconde barrière de sécurité est l'application de la stratégie d'exécution Restrictedpar défaut pour les postes clients et RemoteSigned celle par défaut pour les serveurs(depuis Windows Server 2012 R2).La stratégie Restricted est la plus restrictive. C'est-à-dire qu'elle bloque systémati-quement l'exécution de tout script. Seules les commandes tapées dans le shell serontexécutées. Pour remédier à l'inexécution des scripts, PowerShell requiert que l'utilisa-teur change le mode d'exécution avec la commande Set-ExecutionPolicy<mode d'exécution>. Mais pour ce faire il faut être administrateur de la machine.

Remarque

Peut-être comprenez-vous mieux pourquoi l’utilisation de PowerShell sur vos machinesne constitue pas un accroissement des risques, dans la mesure où certaines règles sontbien respectées.

3.2 Les stratégies d'exécution

PowerShell intègre un concept de sécurité que l'on appelle les stratégies d'exécution(execution policies) pour qu'un script non autorisé ne puisse pas s'exécuter à l'insu del'utilisateur. Il existe sept configurations possibles : Restricted, RemoteSigned,AllSigned, UnRestricted, Bypass, Default et Undefined. À chacune d'ellescorrespond un niveau d'autorisation d'exécution de scripts particulier. Vous pourrezêtre amené à en changer en fonction de la stratégie que vous souhaitez appliquer.

3.2.1 Les différentes stratégies d'exécution

Restricted : c'est la stratégie la plus restrictive, et c'est aussi la stratégie par défautsur les postes clients (de Windows 7 à Windows 10). Elle ne permet pas l'exécution descripts mais autorise uniquement les instructions en ligne de commande tapées dansla console (mode interactif). Cette stratégie peut être considérée comme la plus radi-cale étant donné qu'elle protège contre l'exécution des fichiers .ps1.Lors d'une tentative d'exécution de script avec cette stratégie, un message de ce typeest affiché dans la console :

.\lanceur.ps1 : File C:\temp\lanceur.ps1 cannot be loaded because run-

ning scripts is disabled on this system. For more information, see

about_Execution_Policies at https://go.microsoft.com/fwlink/

?LinkID=135170.

At line:1 char:1

+ .\lanceur.ps1

+ ~~~~~~~~~~~~~

Page 22: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

© E

dit

ions

EN

I -

All r

ights

rese

rved

376Windows PowerShell - Les fondamentaux du langage

PowerShell Core

+ CategoryInfo : SecurityError: (:) [], PSSecurityException

+ FullyQualifiedErrorId : UnauthorizedAccess

Si cette stratégie est celle définie par défaut lors de l'installation de PowerShell, il vousfaudra la changer pour l'exécution de votre premier script.

Remarque

Pour pouvoir modifier la stratégie d’exécution PowerShell, il vous faudra être adminis-trateur local de la machine.

AllSigned : c'est la stratégie permettant l'exécution de scripts la plus « sûre ». Elleautorise uniquement l'exécution des scripts signés. Un script signé est un script com-portant une signature numérique comme celle présentée sur la figure ci-dessous.

Exemple de script signé

Avec la stratégie AllSigned, l'exécution de scripts signés nécessite que vous soyezen possession des certificats correspondants (cf. section Signature des scripts).

Page 23: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

377SécuritéChapitre 12

RemoteSigned : cette stratégie se rapporte à AllSigned à la différence près queseuls les scripts ayant une origine autre que locale nécessitent une signature. Parconséquent, tous vos scripts créés localement peuvent être exécutés sans être signés.À partir de Windows Server 2012 R2, PowerShell s’exécute désormais avec cette stra-tégie d’exécution par défaut, ce qui n’était pas le cas dans les versions antérieures deWindows Server.Si vous essayez d'exécuter un script provenant d'Internet sans que celui-ci ne soit si-gné, vous obtiendrez le message d’erreur suivant :

.\Script.ps1 : File C:\Temp\Script.ps1 cannot be loaded.

The file C:\Temp\Script.ps1 is not digitally signed.

Remarque

Vous vous demandez sûrement comment PowerShell fait pour savoir que notre scriptprovient d'Internet ? Réponse : Grâce aux « Alternate Data Streams » qui sont implé-mentés sous forme de flux cachés depuis des applications de communication tellesque Microsoft Outlook, Internet Explorer, Outlook Express et Windows Messenger (voirpartie traitant des Alternate Data Streams). En gros, lorsqu’un script est téléchargé àpartir d’un client Microsoft, la provenance de celui-ci lui est attachée.

Unrestricted : avec cette stratégie, tout script, peu importe son origine, peut êtreexécuté sans demande de signature.Cette stratégie affiche tout de même un avertissement lorsqu'un script téléchargéd'Internet tente d'être exécuté.

PS > .\script.ps1

Security warning

Run only scripts that you trust. While scripts from the internet can

be useful, this script can potentially harm your computer. If you trust

this script, use the Unblock-File cmdlet to allow the script to run

without this warning message. Do you want to run C:\Temp\script.ps1?

[D] Do not run [R] Run once [S] Suspend [?] Help (default is "D"):

Bypass : c'est la stratégie la moins contraignante, et par conséquent la moins sûre.Rien n'est bloqué et aucun message d'avertissement ne s'affiche. C'est donc la stratégieoù le risque d'exécuter des scripts malveillants est le plus élevé.Undefined : pas de stratégie d'exécution définie dans l'étendue courante. Si toutesles stratégies d'exécution de toutes les étendues sont non définies alors la stratégieeffective appliquée sera la stratégie Restricted.Default : positionne la stratégie par défaut, à savoir Restricted.

Page 24: MVP (Most Windows Les fondamentaux du langage...concrets d’utilisation, et de découvrir l’écosystème PowerShell à travers la présentation d’outils tiers et d’acteurs importants

© E

dit

ions

EN

I -

All r

ights

rese

rved

378Windows PowerShell - Les fondamentaux du langage

PowerShell Core

Remarque

Microsoft a mis en place ces mécanismes afin de tenter de limiter les risques liés àl’exécution de scripts provenant de l’extérieur de l’entreprise et donc potentiellementmalveillants. La configuration par défaut permet d’atteindre cet objectif mais elle negarantit en aucun cas une sécurité parfaite.

3.2.2 Les étendues des stratégies d'exécution

PowerShell permet de gérer l’étendue des stratégies. L’ordre d’application est le suivant :

– Étendue Process : la stratégie d'exécution n'affecte que la session courante (pro-cessus Windows PowerShell). La valeur affectée à l'étendue Process est stockéeen mémoire uniquement ; elle n'est donc pas conservée lors de la fermeture de lasession PowerShell.

– Étendue CurrentUser : la stratégie d'exécution appliquée à l'étendueCurrentUser n'affecte que l'utilisateur courant. Le type de stratégie est stocké defaçon permanente dans la partie du registre HKEY_CURRENT_USER.

– Étendue LocalMachine : la stratégie d'exécution appliquée à l'étendue Local-Machine affecte tous les utilisateurs de la machine. Le type de stratégie est stockéde façon permanente dans la partie du registre HKEY_LOCAL_MACHINE.

La stratégie ayant une priorité 1 est plus propriétaire que celle ayant une priorité 3. Parconséquent, si l'étendue LocalMachine est plus restrictive que l'étendue Process, lastratégie qui s'appliquera sera quand même la stratégie de l'étendue Process. À moinsque cette dernière soit de type Undefined auquel cas PowerShell appliquera la straté-gie de l'étendue CurrentUser puis tentera d'appliquer la stratégie LocalMachine.À noter que l'étendue LocalMachiPne est celle par défaut lorsque l'on applique unestratégie d'exécution sans préciser d'étendue particulière.

3.2.3 Identifier la stratégie d'exécution courante

La stratégie d'exécution courante s'obtient avec la commandelette Get-Execution-Policy.

Exemple

PS > Get-ExecutionPolicy

Restricted

Avec cette commande, nous bénéficions du commutateur -List. Grâce à lui, nousallons savoir quelles stratégies s'appliquent à nos étendues.