のBinaryFormatterにより、次の API は .NET 5 では古いものとしてマークされていました。 これらをコードで使用すると、コンパイル時に警告またはエラー SYSLIB0011 が生成されます。
- System.Exception.SerializeObjectState
- BinaryFormatter.Serialize
- BinaryFormatter.Deserialize
- Formatter.Serialize(Stream, Object)
- Formatter.Deserialize(Stream)
- IFormatter.Serialize(Stream, Object)
- IFormatter.Deserialize(Stream)
.NET 8 以降では、 BinaryFormatter.Serialize と BinaryFormatter.Deserialize は、ほとんどのプロジェクトの種類で実行時に NotSupportedException をスローします。 さらに、 PreserializedResourceWriter.AddBinaryFormattedResource(String, Byte[], String) は 警告として廃止され、次の API は エラーとして廃止されています。
- System.Runtime.Serialization.Formatter
- System.Runtime.Serialization.IFormatter
- System.Runtime.Serialization.Formatters.Binary.BinaryFormatter
対処方法
BinaryFormatterを使用している場合は、そのセキュリティと信頼性の欠陥により、移行することが推奨されます。 詳細については、「BinaryFormatter および関連する型の使用における逆シリアル化リスク」および「優先される代替手段」を参照してください。
警告を抑制する
古い API を使用する必要がある場合は、コードまたはプロジェクト ファイルで警告/エラーを抑制できます。
1 つの違反のみを抑制するには、ソース ファイルにプリプロセッサ ディレクティブを追加して無効にしてから、警告を再度有効にします。
// Disable the warning.
#pragma warning disable SYSLIB0011
// Code that uses obsolete API.
// ...
// Re-enable the warning.
#pragma warning restore SYSLIB0011
プロジェクト内のすべての SYSLIB0011 警告を抑制するには、プロジェクト ファイルに <NoWarn> プロパティを追加します。
<Project Sdk="Microsoft.NET.Sdk">
<PropertyGroup>
...
<NoWarn>$(NoWarn);SYSLIB0011</NoWarn>
</PropertyGroup>
</Project>
詳細については、「警告を表示しない」を参照してください。
こちらも参照ください
.NET