Condividi tramite


CA5367: Non serializzare i tipi con campi puntatore

Proprietà valore
ID regola CA5367
Titolo Non serializzare i tipi con i campi puntatore
Categoria Sicurezza
Correzione che causa un'interruzione o un'interruzione Nessuna interruzione
Abilitato per impostazione predefinita in .NET 8 No

Causa

I puntatori non sono sicuri per i tipi, il che significa che non è possibile garantire la correttezza della memoria a cui puntano. Pertanto, la serializzazione dei tipi con campi puntatore è un rischio per la sicurezza, in quanto può consentire a un utente malintenzionato di controllare il puntatore.

Descrizione regola

Questa regola controlla se è presente una classe serializzabile con un campo o una proprietà puntatore. I membri che non possono essere serializzati possono essere un puntatore, ad esempio membri statici o campi contrassegnati con System.NonSerializedAttribute.

Come correggere le violazioni

Non usare tipi di puntatore per i membri di una classe serializzabile o non serializzare i membri che sono puntatori.

Quando eliminare gli avvisi

Non rischiare di usare i puntatori nei tipi serializzabili.

Esempi di pseudo-codice

Violazione

using System;

[Serializable()]
unsafe class TestClassA
{
    private int* pointer;
}

Soluzione 1

using System;

[Serializable()]
unsafe class TestClassA
{
    private int i;
}

Soluzione 2

using System;

[Serializable()]
unsafe class TestClassA
{
    private static int* pointer;
}