-
Notifications
You must be signed in to change notification settings - Fork 218
Logging
Microsoft Identity Web integrates with the logging available in ASP.NET Core. The MSAL .NET logs are also enabled to assist with troubleshooting and understanding any issues that may occur during token acquisition. The Microsoft.IdentityModel logs are useful to troubleshoot token validation issues.
For information about logging in middleware, see Web API troubleshooting.
To enable logging in Microsoft.Identity.Web, set a log level value for Microsoft.Identity
in the Logging
section of appsettings.json (log levels are covered in later in this article).
For example, this enables logging in Microsoft.Identity.Web and sets the log level to informational:
"Microsoft.Identity": "Information"
When you configure the Logging
section of appsettings.json with a value for Microsoft.Identity
, you enable logging in Microsoft.Identity.Web, MSAL.NET, and IdentityModel.
Example: Logging
section of an appsettings.json file (excerpt) that enables logging events at the informational level:
"AzureAd":
{
...
},
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Identity": "Information"
}
...
To disable detailed logging you can set Logging:LogLevel:Microsoft.Identity.Web
to None
in the configuration.
"AzureAd":
{
...
},
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Identity.Web": "None"
}
...
MSAL.NET, and by extension Microsoft.Identity.Web, provides several log levels via the [LogLevel] enum, including: log level settings:
-
Info
- Recommended for debugging and development,Info
logs the key events of an authentication flow in MSAL .NET. Use with caution in production due to high volume of log events. -
Verbose
- Recommended only for debugging and development,Verbose
logs the most detailed messages. Use with extreme caution in production due to high volume of log events. -
Warning
- Logs abnormal or unexpected events. Typically includes conditions that don't cause the app to fail. -
Error
- Logs errors and exceptions. -
None
- Logs will not be written. To avoid losing log messages from other services, set this log level using the full namespace:"Microsoft.Identity.Web":"None"
Log levels in MSAL.NET have equivalent log levels in ASP.NET as shown in the following table:
MSAL.NET | ASP.NET |
---|---|
Microsoft.Identity.Client.LogLevel.Info | Microsoft.Extensions.Logging.LogLevel.Information |
Microsoft.Identity.Client.LogLevel.Verbose | Microsoft.Extensions.Logging.LogLevel.Debug |
Microsoft.Identity.Client.LogLevel.Verbose | Microsoft.Extensions.Logging.LogLevel.Trace |
Microsoft.Identity.Client.LogLevel.Warning | Microsoft.Extensions.Logging.LogLevel.Warning |
Microsoft.Identity.Client.LogLevel.Error | Microsoft.Extensions.Logging.LogLevel.Error |
Microsoft.Identity.Client.LogLevel.Error | Microsoft.Extensions.Logging.LogLevel.Critical |
Microsoft.Extensions.Logging.LogLevel.None |
By default, neither MSAL.NET nor Microsoft.Identity.Web log any PII or the organizational identifiable information (OII) it might contain. You must manually enable the logging of PII in these libraries.
⚠️ WARNING: You and your application are responsible for complying with all applicable regulatory requirements including but not limited to those set forth by the General Data Protection Regulation (GDPR). Before you enable logging PII, ensure you are able to safely handle this potentially highly sensitive data.
To enable logging PII in Microsoft.Identity.Web, add this line to the AzureAd
section of appsettings.json:
"EnablePiiLogging": true,
Example: Excerpt of an appsettings.json file that shows the EnablePiiLogging
setting in the AzureAd
section of the file and its default value of false
.
"AzureAd":
{
// WARNING: Setting this to 'true' enables logging personal identifiable information (PII) which can contain highly sensitive data.
"EnablePiiLogging": false,
},
"Logging": {
"LogLevel": {
"Default": "Information",
"Microsoft": "Warning",
"Microsoft.Identity": "Information"
}
...
If you use Microsoft.Identity.Web's token cache serializers in .NET Framework or .NET Core, you can still benefit from detailed token cache logs.
To enable detailed logging for Microsoft.Identity.Web's token cache serializers in .NET Framework or .NET Core, set the LoggerFilterOptions.MinLevel property to LogLevel.Debug:
// more code here
app.AddDistributedTokenCache(services =>
{
services.AddDistributedMemoryCache();
services.AddLogging(configure => configure.AddConsole())
.Configure<LoggerFilterOptions>(options => options.MinLevel = Microsoft.Extensions.Logging.LogLevel.Debug);
});
// more code here
To see more sample code using Microsoft Identity Web token cache serializers, see the ConfidentialClientTokenCache code sample on GitHub.
Logs can help you understand MSAL .NET's behavior on the client side, but to understand what's happening on the service side, you might need a correlation ID.
Correlation IDs can help Microsoft Customer Support Services (CSS) and the MSAL team troubleshoot issues by enabling them to trace authentication requests through Microsoft's back-end services.
To get a correlation ID, you can:
-
Get the AuthenticationResult.CorrelationId property value after a successful authentication operation.
-
Get the MsalServiceException.CorrelationId property value of an exception you've caught.
-
Set your own correlation ID in Microsoft.Identity.Web's TokenAcquisitionOptions.CorrelationId property when you request a token.
For example:
public async Task<ActionResult> Details(int id, Guid correlationId) { var value = await _downstreamWebApi.CallWebApiForUserAsync<object, Todo>( ServiceName, null, options => { options.HttpMethod = HttpMethod.Get; options.RelativePath = $"api/todolist/{id}"; options.TokenAcquisitionOptions.CorrelationId = correlationId; }); return View(value); }
- Home
- Why use Microsoft Identity Web?
- Web apps
- Web APIs
- Using certificates
- Minimal support for .NET FW Classic
- Logging
- Azure AD B2C limitations
- Samples
- Web apps
- Web app samples
- Web app template
- Call an API from a web app
- Managing incremental consent and conditional access
- Web app troubleshooting
- Deploy to App Services Linux containers or with proxies
- SameSite cookies
- Hybrid SPA
- Web APIs
- Web API samples
- Web API template
- Call an API from a web API
- Token Decryption
- Web API troubleshooting
- web API protected by ACLs instead of app roles
- gRPC apps
- Azure Functions
- Long running processes in web APIs
- Authorization policies
- Generic API
- Customization
- Logging
- Calling graph with specific scopes/tenant
- Multiple Authentication Schemes
- Utility classes
- Setting FIC+MSI
- Mixing web app and web API
- Deploying to Azure App Services
- Azure AD B2C issuer claim support
- Performance
- specify Microsoft Graph scopes and app-permissions
- Integrate with Azure App Services authentication
- Ajax calls and incremental consent and conditional access
- Back channel proxys
- Client capabilities