JavaScriptSerializer.Deserialize Metodo

Definizione

Overload

Nome Descrizione
Deserialize(String, Type)

Converte una stringa in formato JSON in un oggetto del tipo specificato.

Deserialize<T>(String)

Converte la stringa JSON specificata in un oggetto di tipo T.

Deserialize(String, Type)

Converte una stringa in formato JSON in un oggetto del tipo specificato.

public:
 System::Object ^ Deserialize(System::String ^ input, Type ^ targetType);
public object Deserialize(string input, Type targetType);
member this.Deserialize : string * Type -> obj
Public Function Deserialize (input As String, targetType As Type) As Object

Parametri

input
String

Stringa JSON da deserializzare.

targetType
Type

Tipo dell'oggetto risultante.

Valori restituiti

Oggetto deserializzato.

Eccezioni

input è null.

La lunghezza di input supera il valore di MaxJsonLength.

oppure

È stato superato il limite di ricorsione definito da RecursionLimit .

oppure

input contiene una sequenza di caratteri imprevista.

oppure

input è un tipo di dizionario e è stato rilevato un valore di chiave non stringa.

oppure

input include definizioni di membri non disponibili nel tipo di destinazione.

input contiene una proprietà "__type" che indica un tipo personalizzato, ma il sistema di risoluzione dei tipi attualmente associato al serializzatore non riesce a trovare un tipo gestito corrispondente.

oppure

input contiene una proprietà "__type" che indica un tipo personalizzato, ma il risultato della deserializzazione della stringa JSON corrispondente non può essere assegnato al tipo di destinazione previsto.

oppure

input contiene una proprietà "__type" che indica Object o un tipo non creabile un'istanza, ad esempio un tipo astratto o un'interfaccia.

oppure

È stato effettuato un tentativo di convertire una matrice JSON in un tipo gestito simile a una matrice non supportato per l'uso come destinazione di deserializzazione JSON.

oppure

Non è possibile eseguire la conversione input nel tipo di destinazione.

Commenti

Questo metodo di deserializzazione non tenta di eseguire il cast della radice dell'oggetto grafico a un tipo specifico, il modo in cui il Deserialize metodo esegue.

Si applica a

Deserialize<T>(String)

Converte la stringa JSON specificata in un oggetto di tipo T.

public:
generic <typename T>
 T Deserialize(System::String ^ input);
public T Deserialize<T>(string input);
member this.Deserialize : string -> 'T
Public Function Deserialize(Of T) (input As String) As T

Parametri di tipo

T

Tipo dell'oggetto risultante.

Parametri

input
String

Stringa JSON da deserializzare.

Valori restituiti

T

Oggetto deserializzato.

Eccezioni

La input lunghezza supera il valore di MaxJsonLength.

oppure

È stato superato il limite di ricorsione definito da RecursionLimit .

oppure

input contiene una sequenza di caratteri imprevista.

oppure

input è un tipo di dizionario e è stato rilevato un valore di chiave non stringa.

oppure

input include le definizioni dei membri che non sono disponibili nel tipo T.

input è null.

input contiene una proprietà "__type" che indica un tipo personalizzato, ma il resolver di tipo associato al serializzatore non riesce a trovare un tipo gestito corrispondente.

oppure

input contiene una proprietà "__type" che indica un tipo personalizzato, ma il risultato della deserializzazione della stringa JSON corrispondente non può essere assegnato al tipo di destinazione previsto.

oppure

input contiene una proprietà "__type" che indica Object o un tipo non crea un'istanza,ad esempio un tipo astratto o un'interfaccia.

oppure

È stato effettuato un tentativo di convertire una matrice JSON in un tipo gestito simile a una matrice non supportato per l'uso come destinazione di deserializzazione JSON.

oppure

Non è possibile eseguire la conversione input in T.

Esempio

Nell'esempio seguente viene fornita una semplice illustrazione di come serializzare e deserializzare oggetti dati.

using System;
using System.Collections.Generic;
using System.Web.UI;
using System.Web.Script.Serialization;

namespace ExampleApplication
{
    public partial class _Default : Page
    {
        protected void Page_Load(object sender, EventArgs e)
        {
            var RegisteredUsers = new List<Person>();
            RegisteredUsers.Add(new Person() { PersonID = 1, Name = "Bryon Hetrick", Registered = true });
            RegisteredUsers.Add(new Person() { PersonID = 2, Name = "Nicole Wilcox", Registered = true });
            RegisteredUsers.Add(new Person() { PersonID = 3, Name = "Adrian Martinson", Registered = false });
            RegisteredUsers.Add(new Person() { PersonID = 4, Name = "Nora Osborn", Registered = false });

            var serializer = new JavaScriptSerializer();
            var serializedResult = serializer.Serialize(RegisteredUsers);
            // Produces string value of:
            // [
            //     {"PersonID":1,"Name":"Bryon Hetrick","Registered":true},
            //     {"PersonID":2,"Name":"Nicole Wilcox","Registered":true},
            //     {"PersonID":3,"Name":"Adrian Martinson","Registered":false},
            //     {"PersonID":4,"Name":"Nora Osborn","Registered":false}
            // ]

            var deserializedResult = serializer.Deserialize<List<Person>>(serializedResult);
            // Produces List with 4 Person objects
        }
    }
}
Imports System.Web.Script.Serialization

Public Class _Default
    Inherits Page

    Protected Sub Page_Load(ByVal sender As Object, ByVal e As EventArgs) Handles Me.Load
        Dim RegisteredUsers As New List(Of Person)()
        RegisteredUsers.Add(New Person With {.PersonID = 1, .Name = "Bryon Hetrick", .Registered = True})
        RegisteredUsers.Add(New Person With {.PersonID = 2, .Name = "Nicole Wilcox", .Registered = True})
        RegisteredUsers.Add(New Person With {.PersonID = 3, .Name = "Adrian Martinson", .Registered = False})
        RegisteredUsers.Add(New Person With {.PersonID = 4, .Name = "Nora Osborn", .Registered = False})

        Dim serializer As New JavaScriptSerializer()
        Dim serializedResult = serializer.Serialize(RegisteredUsers)
        ' Produces string value of:
        ' [
        '     {"PersonID":1,"Name":"Bryon Hetrick","Registered":true},
        '     {"PersonID":2,"Name":"Nicole Wilcox","Registered":true},
        '     {"PersonID":3,"Name":"Adrian Martinson","Registered":false},
        '     {"PersonID":4,"Name":"Nora Osborn","Registered":false}
        ' ]

        Dim deserializedResult = serializer.Deserialize(Of List(Of Person))(serializedResult)
        ' Produces List with 4 Person objects
    End Sub
End Class

Richiede una classe denominata Person, illustrata nell'esempio seguente.

namespace ExampleApplication
{
    public class Person
    {
        public int PersonID { get; set; }
        public string Name { get; set; }
        public bool Registered { get; set; }
    }
}
Public Class Person
    Public Property PersonID As Integer
    Public Property Name As String
    Public Property Registered As Boolean
End Class

Commenti

Il Deserialize metodo equivale prima a usare il DeserializeObject metodo per ottenere un oggetto grafico e quindi tentare di eseguire il cast del risultato al tipo T.

Durante la deserializzazione, viene fatto riferimento al resolver di tipo corrente del serializzatore, che determina il tipo gestito da utilizzare durante la conversione di elementi annidati all'interno di matrici e tipi di dizionario. Di conseguenza, il processo di deserializzazione scorre tutti gli elementi annidati di input. Per altre informazioni sui resolver di tipi, vedere la JavaScriptTypeResolver classe .

Si applica a