From afb75a2c8c261f79ac9424269c1daa9e04e9b458 Mon Sep 17 00:00:00 2001 From: Radek Zikmund <32671551+rzikm@users.noreply.github.com> Date: Tue, 25 Jun 2024 12:10:37 +0200 Subject: [PATCH] Improve perf of CredentialCache.GetCredential (#103714) * Improve perf of CredentialCache.GetCredential * Minor changes --- .../src/System/Net/CredentialCacheKey.cs | 51 ++++++++++++------- 1 file changed, 33 insertions(+), 18 deletions(-) diff --git a/src/libraries/Common/src/System/Net/CredentialCacheKey.cs b/src/libraries/Common/src/System/Net/CredentialCacheKey.cs index 0d59c10149315..b84ec32774c61 100644 --- a/src/libraries/Common/src/System/Net/CredentialCacheKey.cs +++ b/src/libraries/Common/src/System/Net/CredentialCacheKey.cs @@ -25,7 +25,7 @@ internal CredentialCacheKey(Uri uriPrefix, string authenticationType) AuthenticationType = authenticationType; } - internal bool Match(Uri uri, string authenticationType) + internal bool Match(Uri uri, int prefixLen, string authenticationType) { if (uri == null || authenticationType == null) { @@ -40,12 +40,12 @@ internal bool Match(Uri uri, string authenticationType) if (NetEventSource.Log.IsEnabled()) NetEventSource.Info(this, $"Match({UriPrefix} & {uri})"); - return IsPrefix(uri, UriPrefix); + return IsPrefix(uri, prefixLen); } // IsPrefix (Uri) // - // Determines whether is a prefix of this URI. A prefix + // Determines whether is a prefix of this URI. A prefix // match is defined as: // // scheme match @@ -55,23 +55,22 @@ internal bool Match(Uri uri, string authenticationType) // // Returns: // True if is a prefix of this URI - private static bool IsPrefix(Uri uri, Uri prefixUri) + private bool IsPrefix(Uri uri, int prefixLen) { Debug.Assert(uri != null); - Debug.Assert(prefixUri != null); + Uri uriPrefix = UriPrefix; - if (prefixUri.Scheme != uri.Scheme || prefixUri.Host != uri.Host || prefixUri.Port != uri.Port) + if (uriPrefix.Scheme != uri.Scheme || uriPrefix.Host != uri.Host || uriPrefix.Port != uri.Port) { return false; } - int prefixLen = prefixUri.AbsolutePath.LastIndexOf('/'); - if (prefixLen > uri.AbsolutePath.LastIndexOf('/')) + if (UriPrefixLength > prefixLen) { return false; } - return string.Compare(uri.AbsolutePath, 0, prefixUri.AbsolutePath, 0, prefixLen, StringComparison.OrdinalIgnoreCase) == 0; + return string.Compare(uri.AbsolutePath, 0, uriPrefix.AbsolutePath, 0, UriPrefixLength, StringComparison.OrdinalIgnoreCase) == 0; } public override int GetHashCode() => @@ -108,21 +107,37 @@ public static bool TryGetCredential(Dictionary longestMatchPrefix) + if (uriPrefixLength == prefixLen) { - // Yes: update the information about currently preferred match - longestMatchPrefix = prefixLen; - mostSpecificMatch = value; - mostSpecificMatchUri = key.UriPrefix; + // we can't get any better than this + break; } } }