Obsolete features in .NET 5+

Starting in .NET 5, some APIs that are newly marked as obsolete make use of two new properties on ObsoleteAttribute.

  • The ObsoleteAttribute.DiagnosticId property tells the compiler to generate build warnings using a custom diagnostic ID. The custom ID allows for obsoletion warning to be suppressed specifically and separately from one another. In the case of the .NET 5+ obsoletions, the format for the custom diagnostic ID is SYSLIB0XXX.

  • The ObsoleteAttribute.UrlFormat property tells the compiler to include a URL link to learn more about the obsoletion.

If you encounter build warnings or errors due to usage of an obsolete API, follow the specific guidance provided for the diagnostic ID listed in the Reference section. Warnings or errors for these obsoletions can't be suppressed using the standard diagnostic ID (CS0618) for obsolete types or members; use the custom SYSLIB0XXX diagnostic ID values instead. For more information, see Suppress warnings.

Reference

The following table provides an index to the SYSLIB0XXX obsoletions in .NET 5+.

Diagnostic ID Warning or error Description
SYSLIB0001 Warning The UTF-7 encoding is insecure and should not be used. Consider using UTF-8 instead.
SYSLIB0002 Error PrincipalPermissionAttribute is not honored by the runtime and must not be used.
SYSLIB0003 Warning Code access security (CAS) is not supported or honored by the runtime.
SYSLIB0004 Warning The constrained execution region (CER) feature is not supported.
SYSLIB0005 Warning The global assembly cache (GAC) is not supported.
SYSLIB0006 Warning Thread.Abort() is not supported and throws PlatformNotSupportedException.
SYSLIB0007 Warning The default implementation of this cryptography algorithm is not supported.
SYSLIB0008 Warning The CreatePdbGenerator() API is not supported and throws PlatformNotSupportedException.
SYSLIB0009 Warning AuthenticationManager is not supported. Methods will no-op or throw PlatformNotSupportedException.
SYSLIB0010 Warning Some remoting APIs are not supported and throw PlatformNotSupportedException.
SYSLIB0011 Warning BinaryFormatter serialization is obsolete and should not be used.
SYSLIB0012 Warning Assembly.CodeBase and Assembly.EscapedCodeBase are only included for .NET Framework compatibility. Use Assembly.Location instead.
SYSLIB0013 Warning Uri.EscapeUriString(String) can corrupt the Uri string in some cases. Consider using Uri.EscapeDataString(String) for query string components instead.
SYSLIB0014 Warning WebRequest, HttpWebRequest, ServicePoint, and WebClient are obsolete. Use HttpClient instead.
SYSLIB0015 Warning DisablePrivateReflectionAttribute has no effect in .NET 6+.
SYSLIB0016 Warning Use the Graphics.GetContextInfo overloads that accept arguments for better performance and fewer allocations.
SYSLIB0017 Warning Strong-name signing is not supported and throws PlatformNotSupportedException.
SYSLIB0018 Warning Reflection-only loading is not supported and throws PlatformNotSupportedException.
SYSLIB0019 Warning The System.Runtime.InteropServices.RuntimeEnvironment members SystemConfigurationFile, GetRuntimeInterfaceAsIntPtr(Guid, Guid), and GetRuntimeInterfaceAsObject(Guid, Guid) are no longer supported and throw PlatformNotSupportedException.
SYSLIB0020 Warning JsonSerializerOptions.IgnoreNullValues is obsolete. To ignore null values when serializing, set DefaultIgnoreCondition to JsonIgnoreCondition.WhenWritingNull.
SYSLIB0021 Warning Derived cryptographic types are obsolete. Use the Create method on the base type instead.
SYSLIB0022 Warning The Rijndael and RijndaelManaged types are obsolete. Use Aes instead.
SYSLIB0023 Warning RNGCryptoServiceProvider is obsolete. To generate a random number, use one of the RandomNumberGenerator static methods instead.
SYSLIB0024 Warning Creating and unloading AppDomains is not supported and throws an exception.
SYSLIB0025 Warning SuppressIldasmAttribute has no effect in .NET 6+.
SYSLIB0026 Warning X509Certificate and X509Certificate2 are immutable. Use the appropriate constructor to create a new certificate.
SYSLIB0027 Warning PublicKey.Key is obsolete. Use the appropriate method to get the public key, such as GetRSAPublicKey().
SYSLIB0028 Warning X509Certificate2.PrivateKey is obsolete. Use the appropriate method to get the private key, such as RSACertificateExtensions.GetRSAPrivateKey(X509Certificate2), or use the X509Certificate2.CopyWithPrivateKey(ECDiffieHellman) method to create a new instance with a private key.
SYSLIB0029 Warning ProduceLegacyHmacValues is obsolete. Producing legacy HMAC values is no longer supported.
SYSLIB0030 Warning HMACSHA1 always uses the algorithm implementation provided by the platform. Use a constructor without the useManagedSha1 parameter.
SYSLIB0031 Warning CryptoConfig.EncodeOID(String) is obsolete. Use the ASN.1 functionality provided in System.Formats.Asn1.
SYSLIB0032 Warning Recovery from corrupted process state exceptions is not supported; HandleProcessCorruptedStateExceptionsAttribute is ignored.
SYSLIB0033 Warning Rfc2898DeriveBytes.CryptDeriveKey(String, String, Int32, Byte[]) is obsolete and is not supported. Use PasswordDeriveBytes.CryptDeriveKey(String, String, Int32, Byte[]) instead.
SYSLIB0034 Warning CmsSigner(CspParameters) is obsolete. Use an alternative constructor instead.
SYSLIB0035 Warning SignerInfo.ComputeCounterSignature() is obsolete. Use the overload that accepts a CmsSigner instead.
SYSLIB0036 Warning Regex.CompileToAssembly is obsolete and not supported. Use RegexGeneratorAttribute with the regular expression source generator instead.
SYSLIB0037 Warning AssemblyName members HashAlgorithm, ProcessorArchitecture, and VersionCompatibility are obsolete and not supported.
SYSLIB0038 Warning SerializationFormat.Binary is obsolete and should not be used.
SYSLIB0039 Warning TLS versions 1.0 and 1.1 have known vulnerabilities and are not recommended. Use a newer TLS version instead, or use SslProtocols.None to defer to OS defaults.
SYSLIB0040 Warning EncryptionPolicy.NoEncryption and EncryptionPolicy.AllowNoEncryption significantly reduce security and should not be used in production code.
SYSLIB0041 Warning The default hash algorithm and iteration counts in Rfc2898DeriveBytes constructors are outdated and insecure. Use a constructor that accepts the hash algorithm and the number of iterations.
SYSLIB0042 Warning ToXmlString and FromXmlString have no implementation for elliptic curve cryptography (ECC) types, and are obsolete. Use a standard import and export format such as ExportSubjectPublicKeyInfo or ImportSubjectPublicKeyInfo for public keys, and ExportPkcs8PrivateKey or ImportPkcs8PrivateKey for private keys.
SYSLIB0043 Warning ECDiffieHellmanPublicKey.ToByteArray() and the associated constructor do not have a consistent and interoperable implementation on all platforms. Use ECDiffieHellmanPublicKey.ExportSubjectPublicKeyInfo() instead.
SYSLIB0044 Warning AssemblyName.CodeBase and AssemblyName.EscapedCodeBase are obsolete. Using them for loading an assembly is not supported.
SYSLIB0045 Warning Cryptographic factory methods accepting an algorithm name are obsolete. Use the parameterless Create factory method on the algorithm type instead.
SYSLIB0046 Warning The ControlledExecution.Run(Action, CancellationToken) method might corrupt the process and should not be used in production code.
SYSLIB0047 Warning XmlSecureResolver is obsolete. Use XmlResolver.ThrowingResolver instead when attempting to forbid XML external entity resolution.
SYSLIB0048 Warning RSA.EncryptValue(Byte[]) and RSA.DecryptValue(Byte[]) are obsolete. Use RSA.Encrypt and RSA.Decrypt instead.
SYSLIB0049 Warning JsonSerializerOptions.AddContext is obsolete. To register a JsonSerializerContext, use either the TypeInfoResolver or TypeInfoResolverChain property.
SYSLIB0050 Warning Formatter-based serialization is obsolete and should not be used.
SYSLIB0051 Warning APIs that support obsolete formatter-based serialization are obsolete. They should not be called or extended by application code.
SYSLIB0052 Warning APIs that support obsolete mechanisms for Regex extensibility are obsolete.
SYSLIB0053 Warning AesGcm should indicate the required tag size for encryption and decryption. Use a constructor that accepts the tag size.
SYSLIB0054 Warning Thread.VolatileRead and Thread.VolatileWrite are obsolete. Use Volatile.Read or Volatile.Write instead.
SYSLIB0055 Warning AdvSimd.ShiftRightLogicalRoundedNarrowingSaturate* methods with signed parameters are obsolete. Use the unsigned overloads instead.
SYSLIB0056 Warning Assembly.LoadFrom with a custom AssemblyHashAlgorithm is obsolete. Use overloads without an AssemblyHashAlgorithm.
SYSLIB0057 Warning X509Certificate2 and X509Certificate constructors for binary and file content are obsolete.
SYSLIB0058 Warning The KeyExchangeAlgorithm, KeyExchangeStrength, CipherAlgorithm, CipherAlgorithmStrength, HashAlgorithm, and HashStrength properties of SslStream are obsolete. Use NegotiatedCipherSuite instead.
SYSLIB0059 Warning SystemEvents.EventsThreadShutdown callbacks aren't run before the process exits. Use AppDomain.ProcessExit instead.

Suppress warnings

It's recommended that you use an available workaround whenever possible. However, if you cannot change your code, you can suppress warnings through a #pragma directive or a <NoWarn> project setting. If you must use the obsolete APIs and the SYSLIB0XXX diagnostic does not surface as an error, you can suppress the warning in code or in your project file.

To suppress the warnings in code:

// Disable the warning.
#pragma warning disable SYSLIB0001

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

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

To suppress the warnings in a project file:

<Project Sdk="Microsoft.NET.Sdk">
  <PropertyGroup>
   <TargetFramework>net6.0</TargetFramework>
   <!-- NoWarn below suppresses SYSLIB0001 project-wide -->
   <NoWarn>$(NoWarn);SYSLIB0001</NoWarn>
   <!-- To suppress multiple warnings, you can use multiple NoWarn elements -->
   <NoWarn>$(NoWarn);SYSLIB0002</NoWarn>
   <NoWarn>$(NoWarn);SYSLIB0003</NoWarn>
   <!-- Alternatively, you can suppress multiple warnings by using a semicolon-delimited list -->
   <NoWarn>$(NoWarn);SYSLIB0001;SYSLIB0002;SYSLIB0003</NoWarn>
  </PropertyGroup>
</Project>

Note

Suppressing warnings in this way only disables the obsoletion warnings you specify. It doesn't disable any other warnings, including obsoletion warnings with different diagnostic IDs.

See also