URI-fråga och fragmentredigering i IHttpClientFactory-loggar
I .NET 9 har standardimplementeringen av ändrats till att rensa frågesträngar vid loggning av IHttpClientFactory URI-information. Den här ändringen förbättrar sekretessen genom att förhindra loggning av potentiellt känslig information i frågesträngar samtidigt som prestandakostnaderna för redigeringen hålls minimala. För scenarier där loggning av frågesträngar är nödvändigt och anses vara säkra kan du åsidosätta det här beteendet.
Version introducerad
Förhandsversion 7 av .NET 9
Tidigare beteende
Tidigare inkluderade standardimplementeringen av IHttpClientFactory
loggning frågesträngar i de meddelanden som skickades till ILogger, vilket oavsiktligt kunde exponera känslig information.
Nytt beteende
Meddelandena som skickas till ILogger har nu fråge- och fragmentdelen ersatt av ett *
tecken.
Typ av icke-bakåtkompatibel ändring
Den här ändringen är en beteendeförändring.
Orsak till ändringen
Den främsta orsaken till den här ändringen är att förbättra sekretessen genom att minska risken för att känslig information loggas oavsiktligt. Frågesträngar innehåller ofta känsliga data och att undanta dem från loggar som standard hjälper till att skydda den här informationen. För att hålla implementeringen enkel och effektiv rensas även fragmentdelen.
Rekommenderad åtgärd
Om ditt program förlitar sig på loggning av frågesträngar och du är säker på att det är säkert att göra det, kan du aktivera frågesträngsloggning globalt genom att ange en AppContext-växel på något av tre sätt:
I projektfilen.
<ItemGroup> <RuntimeHostConfigurationOption Include="System.Net.Http.DisableUriRedaction" Value="true" /> </ItemGroup>
I filen runtimeconfig.json .
{ "runtimeOptions": { "configProperties": { "System.Net.Http.DisableUriRedaction": true } } }
Via en miljövariabel.
Ange
DOTNET_SYSTEM_NET_HTTP_DISABLEURIREDACTION
tilltrue
eller 1.
Annars krävs ingen åtgärd, och standardbeteendet hjälper till att förbättra sekretessaspekterna i ditt program.
Kommentar
Den här växeln inaktiverar även redigering av frågesträngar i HttpClient
EventSource-händelser. Mer information finns i URI-frågeredigering i HttpClient EventSource-händelser.