CA2353: DataSet atau DataTable yang Tidak Aman dalam jenis yang dapat diserialisasikan
Properti | Nilai |
---|---|
ID Aturan | CA2353 |
Judul | Himpunan Data tidak aman atau DataTable dalam jenis yang dapat diserialisasikan |
Golongan | Keamanan |
Perbaikan bersifat disruptif atau non-disruptif | Non-disruptif |
Diaktifkan secara default di .NET 9 | No |
Penyebab
Kelas atau struct yang ditandai dengan atribut serialisasi XML atau atribut kontrak data berisi bidang atau properti DataSet atau DataTable.
Atribut serialisasi XML meliputi:
- XmlAnyAttributeAttribute
- XmlAnyElementAttribute
- XmlArrayAttribute
- XmlArrayItemAttribute
- XmlChoiceIdentifierAttribute
- XmlElementAttribute
- XmlEnumAttribute
- XmlIgnoreAttribute
- XmlIncludeAttribute
- XmlRootAttribute
- XmlTextAttribute
- XmlTypeAttribute
Atribut serialisasi kontrak data meliputi:
Deskripsi aturan
Saat mendeserialisasi input yang tidak tepercaya dan grafik objek yang dideserialisasi berisi DataSet atau DataTable, penyerang dapat membuat payload berbahaya untuk melakukan penolakan serangan layanan. Mungkin ada kerentanan eksekusi kode jarak jauh yang tidak diketahui.
Aturan ini menemukan jenis yang tidak aman saat dideserialisasi. Jika kode Anda tidak mendeserialisasi jenis yang ditemukan, maka Anda tidak memiliki kerentanan deserialisasi.
Untuk informasi selengkapnya, lihat Panduan keamanan Himpunan Data dan DataTable.
Cara memperbaiki pelanggaran
- Jika memungkinkan, gunakan Entity Framework daripada DataSet dan DataTable.
- Buat data yang diserialisasi agar tahan rusak. Setelah serialisasi, tanda tangani secara kriptografi data yang diserialisasi. Sebelum deserialisasi, validasi tanda tangan kriptografi. Lindungi kunci kriptografi agar tidak diungkapkan dan didesain untuk rotasi kunci.
Kapan harus menekan peringatan
Aman untuk menyembunyikan peringatan dari aturan ini jika:
- Jenis yang ditemukan oleh aturan ini tidak pernah dideserialisasi, baik secara langsung maupun tidak langsung.
- Anda mengetahui bahwa input-nya tepercaya. Pertimbangkan bahwa batas kepercayaan dan aliran data aplikasi Anda dapat berubah dari waktu ke waktu.
- Anda telah mengambil salah satu tindakan pencegahan dalam Cara memperbaiki pelanggaran.
Menyembunyikan peringatan
Jika Anda hanya ingin menyembunyikan satu pelanggaran, tambahkan arahan praprosedur ke file sumber Anda untuk dinonaktifkan lalu aktifkan kembali aturannya.
#pragma warning disable CA2353
// The code that's violating the rule is on this line.
#pragma warning restore CA2353
Untuk menonaktifkan aturan untuk file, folder, atau proyek, atur tingkat keparahannya ke none
dalam file konfigurasi.
[*.{cs,vb}]
dotnet_diagnostic.CA2353.severity = none
Untuk informasi selengkapnya, lihat Cara menyembunyikan peringatan analisis kode.
Contoh kode semu
Pelanggaran
using System.Data;
using System.Runtime.Serialization;
[XmlRoot]
public class MyClass
{
public DataSet MyDataSet { get; set; }
}
Aturan terkait
CA2350: Pastikan input DataTable.ReadXml() dipercaya
CA2351: Pastikan input DataSet.ReadXml() tepercaya
CA2355: DataSet atau DataTable yang tidak aman dalam grafik objek yang dideserialisasikan
CA2356: DataSet atau DataTable Tidak Aman dalam grafik objek yang dideserialisasi web