SYSLIB0011:BinaryFormatter は旧型式

BinaryFormatterセキュリティの脆弱性により、.NET 5 では、次の API は古いものとしてマークされています。 これらをコードで使用すると、コンパイル時に警告またはエラー SYSLIB0011 が生成されます。

.NET 8 以降では、BinaryFormatter.SerializeBinaryFormatter.Deserialize が、プロジェクトのほとんどの種類で、実行時に NotSupportedException をスローします。 また、PreserializedResourceWriter.AddBinaryFormattedResource(String, Byte[], String)警告として廃止されており、次の API はエラーとして廃止されています。

問題回避

BinaryFormatter を使用している場合は、セキュリティと信頼性の欠陥があるため、それから移行する必要があります。 詳細については、「BinaryFormatter および関連する型を使用するときの逆シリアル化のリスク」および「推奨される代替手段」を参照してください。

警告を抑制する

古い API を使用する必要がある場合は、コードまたはプロジェクト ファイルで警告またはエラーを抑制することができます。

単一の違反だけを抑制するには、ソース ファイルにプリプロセッサ ディレクティブを追加して警告を無効にしてから、再度有効にします。

// 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>

詳細については、「警告を表示しない」を参照してください。

関連項目