共用方式為


SYSLIB0045:某些密碼編譯 Factory 方法已淘汰

下列 System.Security.Cryptography 方法從 .NET 7 開始已淘汰。 在程式碼中使用這些 API 會導致在編譯時期產生警告 SYSLIB0045。 這些 Factory 方法都會接受代表演算法名稱的字串引數。 這些方法會呼叫 CryptoConfig.CreateFromName,並將結果轉換成傳回型別。

這些方法標示為 [Obsolete] 是因為在已修剪的應用程式中,這些方法可以傳回 null,而在未修剪的應用程式中則不會傳回。 此外,在非修剪的應用程式中,這些方法的例外狀況型行為偶爾會在呼叫端產生意外狀況,且許多已知的識別碼都與本身標示 [Obsolete] 的型別相關聯。

因應措施

傳遞常數字串的呼叫應該變更為無參數的 Factory 方法或強式呼叫,以建立適當的型別。 例如,呼叫 Aes.Create("AES") 可使用 Aes.Create()new AesCryptoServiceProvider() 取代。 因為 AesCryptoServiceProvider 型別也會標示為 [Obsolete],所以 Aes.Create() 是較為偏好的取代型別。

傳遞非常數字串的呼叫可以使用自己的查閱表格,或變更為直接呼叫 CryptoConfig.CreateFromName

隱藏警告

若您必須使用已淘汰的 API,您可以在程式碼或專案檔中隱藏警告。

若要只隱藏單一違規,請將前置處理器指示詞新增至原始程式碼檔案,以停用並重新啟用警告。

// Disable the warning.
#pragma warning disable SYSLIB0045

// Code that uses obsolete API.
// ...

// Re-enable the warning.
#pragma warning restore SYSLIB0045

若要隱藏專案中的所有 SYSLIB0045 警告,請將 <NoWarn> 屬性新增至專案檔。

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   ...
   <NoWarn>$(NoWarn);SYSLIB0045</NoWarn>
  </PropertyGroup>
</Project>

如需詳細資訊,請參閱隱藏警告