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.
Action recommandée
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
surtrue
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.