5

Jest to związane z tym question, ale w tym przypadku nie jest to coś, co zwracam, ale raczej wiążące modelu. Używam Postmark do obsługi przychodzących wiadomości e-mail, które publikuje na stronie z JSON payload.Jak mogę obsłużyć duże wejście JSON z Postmark w mojej aplikacji MVC?

Mam modelu, jak poniżej i działania, które przyjmuje ten ładunek JSON (wysłany z aplikacji/json) i przetwarza go.

public class EmailModel 
{ 
    public IDictionary<string, string> Headers { get; set; } 
    public string From { get; set; } 
    public string Cc { get; set; } 
    public string HtmlBody { get; set; } 
    public string TextBody { get; set; } 
    public string ReplyTo { get; set; } 
    public string Tag { get; set; } 
    public string To { get; set; } 
    public string MessageID { get; set; } 
    public string MailboxHash { get; set; } 
    public string Subject { get; set; } 
    public List<Attachment> Attachments { get; set; } 
} 

public class Attachment 
{ 
    public string Content { get; set; } 
    public int ContentLength { get; set; } 
    public string ContentType { get; set; } 
    public string Name { get; set; } 

} 

Działa to dobrze dla małych załączników, ale dla wszystkiego, co przekracza domyślną właściwość maxJsonLength powoduje błąd w deserializacji. ("Błąd podczas serializacji lub deserializacji za pomocą JSON JavaScriptSerializer.Długość łańcucha przekracza wartość ustawioną w właściwości maxJsonLength.") Ponieważ chcę zaakceptować załączniki obrazu, oznacza to, że większość obrazów zawiedzie.

Próbowałem już aktualizacji pliku web.config, ale jak w przypadku innych wątków, to nie pomaga kontrolerom MVC. Myślę, że prawdopodobnie mogę zrobić to, co wspomniano w niestandardowym IModelBinderze, ale walczę z tym, jak przechwycić deserializację. (Innymi słowy, nadal nie działa, ponieważ deserializacja już się wydarzyła).

Wszelkie sugestie? Jestem pewien, że to jest po prostu coś głupiego, że mi brakuje ....

Odpowiedz

3

Mogłeś napisać custom JsonValueProviderFactory który wykorzystuje Json.NET:

public sealed class JsonDotNetValueProviderFactory : ValueProviderFactory 
{ 
    public override IValueProvider GetValueProvider(ControllerContext controllerContext) 
    { 
     if (controllerContext == null) 
      throw new ArgumentNullException("controllerContext"); 

     if (!controllerContext.HttpContext.Request.ContentType.StartsWith("application/json", StringComparison.OrdinalIgnoreCase)) 
      return null; 

     var reader = new StreamReader(controllerContext.HttpContext.Request.InputStream); 
     var bodyText = reader.ReadToEnd(); 

     return String.IsNullOrEmpty(bodyText) ? null : new DictionaryValueProvider<object>(JsonConvert.DeserializeObject<ExpandoObject>(bodyText, new ExpandoObjectConverter()) , CultureInfo.CurrentCulture); 
    } 
} 

iw swoim Application_Start:

ValueProviderFactories.Factories.Remove(ValueProviderFactories.Factories.OfType<JsonValueProviderFactory>().FirstOrDefault()); 
ValueProviderFactories.Factories.Add(new JsonDotNetValueProviderFactory()); 
+0

Dzięki Darin - wygląda na dobre podejście. Jutro zamierzam dać temu szansę. –

+0

@Darin Czy istnieje sposób na dodanie tego tylko do konkretnego kontrolera zamiast do całej aplikacji? –

+0

Cześć Darin, czy mógłbyś spojrzeć na moje pytanie (http://stackoverflow.com/q/32970848/7850), aby zobaczyć, dlaczego to nie działa dla mnie? Dzięki! –

Powiązane problemy