martes, 30 de noviembre de 2021

Error al usar await q.Content.ReadFromJsonAsync

 Sintomas:

En Blazor WASM  se produce un error  

Microsoft.AspNetCore.Components.WebAssembly.Rendering.WebAssemblyRenderer[100]       Unhandled exception rendering component: Each parameter in the deserialization constructor on type 'CRM.Shared.Models.Notas.FilaTabla' must bind to an object property or field on deserialization. Each parameter name must match with a property or field on the object. The match can be case-insensitive.

Al convertir la respuesta de JSON a un objeto C# mediante q.Content.ReadFromJsonAsync .

Lo que te sorprende es que la clase esta definida en el proyecto Shared usado tanto por el proyecto Server del controlador Web API que envia la respuesta como por la parte del cliente donde se realiza la llamada a Content.ReadFromJsonAsync. Entonces, ¿por qué difieren los nombres?

Solución:

La clase no tiene un constructor vacio.

Observaciones

Es fácil olvidarse del constructor vacío cuando creas un construtor con parametro un entidad de EF.

viernes, 12 de noviembre de 2021

Error "Data is Null. This method or property cannot be called on Null values" en Entity Framework 6

 Descripción del problema

Acabas de instalar VS2022 y .NET6 SDK, creas un proyecto que accede a una base de datos  Para generar los modelos y mapeos usas ingeniería inversa, por ejemplo Entity Framework Generator

Creas un controlador API Get para obtener una lista de fabricas desde Blazor. ¡Oh sorpresa! La cosa no funciona. 

El mensaje de error es: "Data is Null. This method or property cannot be called on Null values"

Resolución

Debes deshabilitar Admite valores NULL en Compilación/general del proyecto donde tienes los modelos y dbcontext para acceder a la base de datos.

Explicación

En C#8 cuando habilitas la característica NRT debes usar string? para una propiedad de cadena que admita nulos y string para una que no los admita.

EF6 CORE implementa NRT mediante anotaciones, pero los generadores databasefirst no asocian el tipo string? a las propiedades mapeadas a columnas varchar nullables.