<p>Il y a beaucoup de termes surchargés ici, et un changement entre IIS 7 et 7.5.</p>
<h2><a name="p-20086-app-pool-identity-vs-compte-du-pool-dapplications-1" class="anchor" href="#p-20086-app-pool-identity-vs-compte-du-pool-dapplications-1" aria-label="Heading link"></a>App Pool Identity vs Compte du pool d’applications</h2>
<p>Commençons par l’identité du pool d’applications (identité avec un i minuscule, ce que j’appelle le <em>Compte du pool d’applications</em> pour éviter toute ambiguïté) :</p>
<p>Selon ma compréhension, le <strong>Compte du pool d’applications</strong> est le compte utilisé pour <em>démarrer</em> un pool d’applications, et l’identité que le pool d’applications assume lorsqu’il n’usurpe l’identité de personne d’autre.</p>
<p>Donc, quelle que soit l’identité que vous attribuez au pool d’applications, celui-ci va avoir besoin de pouvoir <strong>lire les fichiers dans le dossier de contenu</strong> : en particulier {mais pas uniquement} les fichiers <strong>web.config</strong> (qui font partie de la configuration IIS et contrôlent ce que le pool d’applications va faire).</p>
<p>S’il ne peut pas accéder à un dossier, il supposera qu’il pourrait y avoir un fichier web.config important (susceptible de tout changer) à l’intérieur, et affichera une erreur. Le Compte du pool d’applications a donc besoin d’un accès en <em>Lecture</em> à tous les dossiers de contenu.</p>
<h2><a name="p-20086-applicationpoolidentity-2" class="anchor" href="#p-20086-applicationpoolidentity-2" aria-label="Heading link"></a>ApplicationPoolIdentity</h2>
<p>Pourquoi différencier le Compte du pool d’applications (l’identité du pool d’applications) de l’App Pool Identity ? Parce que <strong>ApplicationPoolIdentity</strong> (avec les majuscules spéciales) est un nouveau <em>type</em> de compte - un compte de service managé - introduit et défini par défaut dans IIS 7.5 / Windows 2008 R2, et disponible à partir de Windows 2008 SP2 également (mais pas par défaut).</p>
<p>Voir <a href="http://learn.iis.net/page.aspx/624/application-pool-identities/">Application Pool Identities sur IIS.Net</a></p>
<p>Lorsque vous créez un site web sous 2008 R2 ou ultérieur via l’interface graphique :</p>
<ul>
<li>
<p>un pool d’applications sera créé pour héberger ce site web, et</p>
</li>
<li>
<p>le type de compte sera <em>ApplicationPoolIdentity</em>, au lieu de Network Service (la valeur par défaut sous 2008), Local Service ou Local System</p>
</li>
<li>
<p>une identité virtuelle, IIS AppPools\NomDuPoolDApplications, sera mise à disposition pour être utilisée comme principal de sécurité sur la machine locale</p>
</li>
</ul>
<p>Avec 2008 RTM, le compte par défaut du pool d’applications était Network Service <em>plus</em> un identifiant/différenciateur unique du pool d’applications ; le nouveau type de compte AppPoolIdentity de R2/SP2 est un compte <em>similaire à</em> Network Service (c’est-à-dire qu’il représente l’ordinateur lors des connexions externes), mais empêche l’usurpation d’identité d’un autre pool d’applications au sein de la même machine.</p>
<h2><a name="p-20086-retour-la-question-originale-3" class="anchor" href="#p-20086-retour-la-question-originale-3" aria-label="Heading link"></a>Retour à la question originale :</h2>
<ul>
<li></li>
</ul>
<p><strong>Le compte du pool d’applications</strong> définit <strong>sous quelle identité</strong> votre application s’exécute <em>lorsqu’elle n’usurpe l’identité de personne d’autre</em></p>
<ul>
<li></li>
</ul>
<p><strong>La méthode d’authentification</strong> décrit <strong>comment</strong> vous allez authentifier les clients (afin d’usurper leur identité)</p>
<ul>
<li></li>
</ul>
<p><strong>Le compte utilisateur anonyme</strong> définit sous quelle identité vous allez vous exécuter lorsque vous usurpez l’identité d’un utilisateur pour une requête qui n’est pas authentifiée - IUSR est un tel utilisateur.</p>
<p>À noter, avec IIS 7.5+, vous pouvez définir le compte utilisateur anonyme comme étant l’Application Pool Identity (dans les propriétés de la méthode d’authentification anonyme), ce qui pourrait simplifier l’isolation et la sécurisation du contenu pour un site web donné.</p>
<p>Définissez les permissions en utilisant le format IIS AppPool\NomDeVotreSite pour le nom (voir <a href="https://docs.microsoft.com/en-us/archive/blogs/tristank/iusr-vs-application-pool-identity-why-use-either">cet article</a>).</p>