diff --git a/src/Shared/LayoutRenderers/AspNetRequestCookieLayoutRenderer.cs b/src/Shared/LayoutRenderers/AspNetRequestCookieLayoutRenderer.cs
index 3335ada40..524040f91 100644
--- a/src/Shared/LayoutRenderers/AspNetRequestCookieLayoutRenderer.cs
+++ b/src/Shared/LayoutRenderers/AspNetRequestCookieLayoutRenderer.cs
@@ -25,6 +25,8 @@ namespace NLog.Web.LayoutRenderers
///
/// ${aspnet-request-cookie:OutputFormat=Flat}
/// ${aspnet-request-cookie:OutputFormat=Json}
+ /// ${aspnet-request-cookie:OutputFormat=Json:CookieNames=username}
+ /// ${aspnet-request-cookie:OutputFormat=Json:Exclude=access_token}
///
///
[LayoutRenderer("aspnet-request-cookie")]
@@ -37,6 +39,24 @@ public class AspNetRequestCookieLayoutRenderer : AspNetLayoutMultiValueRendererB
///
public List CookieNames { get; set; }
+ ///
+ /// Gets or sets the keys to exclude from the output. If omitted, none are excluded.
+ ///
+ ///
+#if ASP_NET_CORE
+ public ISet Exclude { get; set; }
+#else
+ public HashSet Exclude { get; set; }
+#endif
+
+ ///
+ /// Initializes a new instance of the class.
+ ///
+ public AspNetRequestCookieLayoutRenderer()
+ {
+ Exclude = new HashSet(new[] { "AUTH", "SESS_ID" }, StringComparer.OrdinalIgnoreCase);
+ }
+
///
/// Renders the ASP.NET Cookie appends it to the specified .
///
@@ -51,38 +71,23 @@ protected override void DoAppend(StringBuilder builder, LogEventInfo logEvent)
}
var cookies = httpRequest.Cookies;
- var cookieNames = GetCookieNames(cookies)?.ToList();
- if (cookieNames?.Count > 0 && cookies?.Count > 0)
+ if (cookies?.Count > 0)
{
- var cookieValues = GetCookies(cookies, cookieNames);
+ bool excludeKeys = (CookieNames == null || CookieNames.Count == 0) && Exclude?.Count > 0;
+ var cookieValues = GetCookieValues(cookies, excludeKeys);
SerializePairs(cookieValues, builder, logEvent);
}
}
- ///
- /// Get cookies names to render
- ///
- ///
- ///
- private IEnumerable GetCookieNames(Cookies cookies)
- {
- if (CookieNames != null && CookieNames.Any())
- return CookieNames;
-
- var keys = cookies.Keys;
-
#if !ASP_NET_CORE
- return keys.Cast();
-#else
- return keys;
-#endif
- }
-
-#if !ASP_NET_CORE
- private IEnumerable> GetCookies(HttpCookieCollection cookies, IEnumerable cookieNames)
+ private IEnumerable> GetCookieValues(HttpCookieCollection cookies, bool excludeKeys)
{
+ var cookieNames = CookieNames?.Count > 0 ? CookieNames : cookies.Keys.Cast().ToList();
foreach (var cookieName in cookieNames)
{
+ if (excludeKeys && Exclude.Contains(cookieName))
+ continue;
+
var httpCookie = cookies[cookieName];
if (httpCookie == null)
{
@@ -111,10 +116,14 @@ private IEnumerable> GetCookies(HttpCookieCollectio
}
}
#else
- private IEnumerable> GetCookies(IRequestCookieCollection cookies, IEnumerable cookieNames)
+ private IEnumerable> GetCookieValues(IRequestCookieCollection cookies, bool excludeKeys)
{
+ var cookieNames = CookieNames?.Count > 0 ? CookieNames : cookies.Keys;
foreach (var cookieName in cookieNames)
{
+ if (excludeKeys && Exclude.Contains(cookieName))
+ continue;
+
if (!cookies.TryGetValue(cookieName, out var cookieValue))
{
continue;
diff --git a/src/Shared/LayoutRenderers/AspNetRequestFormLayoutRenderer.cs b/src/Shared/LayoutRenderers/AspNetRequestFormLayoutRenderer.cs
index 79dc80726..dc6f63cf3 100644
--- a/src/Shared/LayoutRenderers/AspNetRequestFormLayoutRenderer.cs
+++ b/src/Shared/LayoutRenderers/AspNetRequestFormLayoutRenderer.cs
@@ -48,12 +48,12 @@ public class AspNetRequestFormLayoutRenderer : AspNetLayoutMultiValueRendererBas
#endif
///
- /// Constructor
+ /// Initializes a new instance of the class.
///
public AspNetRequestFormLayoutRenderer()
{
Include = new HashSet(StringComparer.OrdinalIgnoreCase);
- Exclude = new HashSet(StringComparer.OrdinalIgnoreCase);
+ Exclude = new HashSet(new[] { "Password", "Pwd" }, StringComparer.OrdinalIgnoreCase);
}
///
diff --git a/tests/Shared/LayoutRenderers/AspNetCookieLayoutRendererTests.cs b/tests/Shared/LayoutRenderers/AspNetCookieLayoutRendererTests.cs
index 2af3aa788..0f9bcb45d 100644
--- a/tests/Shared/LayoutRenderers/AspNetCookieLayoutRendererTests.cs
+++ b/tests/Shared/LayoutRenderers/AspNetCookieLayoutRendererTests.cs
@@ -30,6 +30,19 @@ public void NullKeyRendersAllCookies()
Assert.Equal(expectedResult, result);
}
+ [Fact]
+ public void NullKeyRendersAllCookiesExceptExcluded()
+ {
+ var expectedResult = "Key1=TEST1";
+ var renderer = CreateRenderer();
+ renderer.CookieNames = null;
+ renderer.Exclude.Add("key");
+
+ string result = renderer.Render(new LogEventInfo());
+
+ Assert.Equal(expectedResult, result);
+ }
+
[Fact]
public void KeyNotFoundRendersEmptyString_Flat_Formatting()
{