Partager via


Réaction des requêtes URI dans les événements HttpClient EventSource

Dans .NET 9, le comportement par défaut des EventSource événements émis par HttpClient et SocketsHttpHandler (EventSource nom : System.Net.Http) a été modifié pour nettoyer les chaînes de requête. Cette modification améliore la confidentialité en empêchant la journalisation des informations potentiellement sensibles contenues dans les chaînes de requête. Si nécessaire, vous pouvez remplacer ce comportement.

Version introduite

.NET 9 Préversion 7

Comportement précédent

Auparavant, les événements émis par et SocketsHttpHandler inclus des informations de HttpClient chaîne de requête, susceptibles d’exposer par inadvertance des informations sensibles.

Nouveau comportement

Avec la modification de dotnet/runtime#104741, les chaînes de requête sont remplacées par un * caractère HttpClient et SocketsHttpHandler des événements, par défaut. Cette modification affecte des événements et des paramètres spécifiques tels que pathAndQuery dans RequestStart et redirectUri dans Redirect.

Type de changement cassant

Ce changement est un changement de comportement.

Raison du changement

La principale raison de ce changement était d’améliorer la confidentialité en réduisant le risque de journalisation par inadvertance des informations sensibles. Les chaînes de requête contiennent souvent des données sensibles et les réactent à partir de journaux par défaut vous aident à protéger ces informations.

Si vous avez besoin d’informations de chaîne de requête lors de la consommation HttpClient ou SocketsHttpHandler des événements et que vous êtes certain qu’il est sûr de le faire, vous pouvez activer la journalisation des chaînes de requête globalement en définissant un commutateur AppContext de l’une des trois manières suivantes :

  • Dans le fichier projet.

    <ItemGroup>
      <RuntimeHostConfigurationOption Include="System.Net.Http.DisableUriRedaction" Value="true" />
    </ItemGroup>
    
  • Dans le fichier runtimeconfig.json.

    {
        "runtimeOptions": {
            "configProperties": {
                "System.Net.Http.DisableUriRedaction": true
            }
        }
    }
    
  • Via une variable d’environnement.

    Définissez DOTNET_SYSTEM_NET_HTTP_DISABLEURIREDACTION sur true ou 1.

Sinon, aucune action n’est requise et le comportement par défaut permet d’améliorer les aspects de confidentialité de votre application.

Remarque

Ce commutateur désactive également la réaction de chaîne de requête dans les journaux par défaut IHttpClientFactory . Pour plus d’informations, consultez la rédaction des requêtes d’URI dans les journaux IHttpClientFactory.

API affectées