Compartir a través de


DataContractSerializer.MaxItemsInObjectGraph Propiedad

Definición

Obtiene el número máximo de elementos de un gráfico de objetos que se van a serializar o deserializar.

public:
 property int MaxItemsInObjectGraph { int get(); };
public int MaxItemsInObjectGraph { get; }
member this.MaxItemsInObjectGraph : int
Public ReadOnly Property MaxItemsInObjectGraph As Integer

Valor de propiedad

El número máximo de elementos para serializar o deserializar. El valor predeterminado es Int32.MaxValue.

Excepciones

El número de elementos supera el valor máximo.

Comentarios

Esta propiedad se puede establecer mediante declaración en configuración o de forma imperativa en el código. Para establecerlo en configuración, agregue un comportamiento personalizado a la sección de comportamientos y agregue el siguiente valor.

<behaviors>    <behavior name="MyServiceBehavior">        <dataContractSerializer maxItemsInObjectGraph="3" />    </behavior></behaviors>

Para establecer esta propiedad de forma imperativa en el código, busque la descripción de operación del servicio, obtenga después el comportamiento de operación y, por último, establezca la propiedad como se muestra en el código siguiente.

OperationDescription operation = host.Description.Endpoints[0].Contract.Operations.Find("MyOperationName");operation.Behaviors.Find<DataContractSerializerOperationBehavior>().MaxItemsInObjectGraph = 3;

La propiedad MaxItemsInObjectGraph especifica el número máximo de objetos que el serializador serializa o deserializa en una llamada única al método ReadObject. (El método siempre lee un objeto raíz, pero este objeto puede tener otros objetos en sus miembros de datos. Esos objetos pueden tener otros objetos, etc.). El valor predeterminado es MaxValue. Tenga en cuenta que al serializar o deserializar las matrices, cada entrada de matriz cuenta como un objeto independiente. Observe también que algunos objetos pueden tener una representación de memoria grande, así que esta cuota sola puede no ser suficiente para evitar ataques por denegación de servicio. Para más información, consulte Consideraciones de seguridad para datos. Si necesita aumentar esta cuota más allá de su valor predeterminado, es hacerlo tanto en el lado emisor (de serialización) como en el receptor (de deserialización). Lo aplica tanto cuando lee como cuando escribe datos.

Se aplica a