Ir al contenido principal

Data Annotations .NET

Validaciones en .NET con Data Annotations 

En el desarrollo de aplicaciones con .NET, una de las formas más eficientes de validar y describir las propiedades de un modelo es mediante Data Annotations. En este artículo exploraremos qué son, cómo utilizarlas y en qué proyectos son aplicables.

¿Qué son las Data Annotations?

Las Data Annotations son atributos que se agregan a las propiedades de un modelo para validar datos, proporcionar metadatos o describir su comportamiento. Estas anotaciones permiten que .NET valide automáticamente la entrada de datos sin necesidad de escribir código adicional.

Por ejemplo, si en el modelo existe un campo obligatorio o un formato específico, con solo agregar una anotación se puede verificar su validez automáticamente.

Biblioteca Necesaria

    using System.ComponentModel.DataAnnotations;

Esta biblioteca incluye las anotaciones más comunes como Required, StringLength, RegularExpression, Range y otras que veremos más adelante. Si se trabaja con ASP.NET MVC o Entity Framework, esta biblioteca ya viene incluida por defecto en el proyecto.

Ejemplo Práctico

Veamos un ejemplo sencillo. Se está desarrollando un sistema de gestión de Artículos y  se necesita validar que el código del artículo sea obligatorio, tenga un formato específico y que su nombre tenga una longitud máxima entonces se podría manejar de la siguiente manera:

 using System.ComponentModel.DataAnnotations;

namespace Entidades
{
    public class Articulo
    {
        // Propiedades
        [Required(ErrorMessage = "El código del artículo es obligatorio.")]
        [RegularExpression(@"^[a-zA-Z0-9]{10}$", ErrorMessage = "Código inválido.")]
        [Display(Name = "Código")]
        public string CodArt { get; set; }

        // Constructor
        public Articulo() { }
    }
}

Explicación:
  • [Required]: Indica que el campo es obligatorio y no puede quedar vacío.
  • [RegularExpression]: Valida un formato específico usando expresiones regulares. (Expresiones regulares en .NET)
  • [Display]: Cambia el nombre visible en la interfaz de usuario.

Además de las comentadas, existen otras anotaciones comunes en .NET, especialmente dentro del espacio de nombres System.ComponentModel.DataAnnotations

Algunos ejemplos podrían ser:

1. [StringLength]: Especifica la longitud máxima y mínima permitida de una cadena.
[StringLength(50, MinimumLength = 5, ErrorMessage = "El nombre debe tener entre 5 y 50 caracteres.")]
2. [Range]: Restringe el valor de un campo a un rango numérico o de fechas.
[Range(18, 99, ErrorMessage = "La edad debe estar entre 18 y 99 años.")]
3. [MaxLength] | [MinLength]: Es similar a StringLength, especifica la longitud máxima o mínima de una cadena o colección.
[MaxLength(100, ErrorMessage = "El nombre no puede tener más de 100 caracteres.")]
[MinLength(3, ErrorMessage = "El nombre debe tener al menos 3 caracteres.")]
4. [EmailAddress]: Valida que el valor sea un formato de correo electrónico válido.
[EmailAddress(ErrorMessage = "Debe ser una dirección de correo válida.")]
5. [Phone]: Valida que el valor sea un número de teléfono válido.
[Phone(ErrorMessage = "Número de teléfono inválido.")]
6. [Url]: Valida que el valor sea una URL válida.
[Url(ErrorMessage = "Debe ser una URL válida.")]
7. [Key]: Define una clave primaria en un modelo (útil en Entity Framework).
[Key]
public int Id { get; set; }
Entre otras.

¿En qué tipo de proyectos puedo usar Data Annotations?

Las Data Annotations son extremadamente versátiles y es posible utilizarlas en varios tipos de proyectos:

  • ASP.NET MVC: Ideal para validar datos en formularios web y mostrar mensajes de error al usuario.
  • ASP.NET Core: Permite validar modelos en APIs REST o aplicaciones web modernas.
  • Entity Framework (EF y EF Core): Las anotaciones ayudan a definir restricciones y metadatos en la base de datos.
  • Aplicaciones de escritorio: Puedes usar las anotaciones con WPF o WinForms junto con validaciones manuales.
Dicho esto..


Debemos tener presente que las validaciones mediante Data Annotations no se ejecutan automáticamente al crear un objeto manualmente con un constructor en .NET. Estas validaciones forman parte del modelo de validación de .NET y otras herramientas como Entity Framework y se aplican explícitamente en casos como los siguientes (a nivel de ejemplo):

.NET FW MVC o .NET Core: Cuando se envían datos desde una vista (formulario) hacia un controlador, el framework de MVC valida automáticamente el modelo utilizando las Data Annotations. 

Esto se activa mediante ModelState.IsValid en tu controlador. ModelState.IsValid verifica las propiedades del modelo decoradas con Data Annotations y muestra mensajes de error cuando la validación falla.

Validaciones Manuales con Validator.TryValidateObject: Si se crea un objeto manualmente (por ejemplo, con un constructor), las validaciones no se ejecutarán automáticamente. 

Para validar manualmente las Data Annotations, se debe utilizar la clase Validator del namespace System.ComponentModel.DataAnnotations.

Entity Framework: En Entity Framework y EF Core, las validaciones se aplican automáticamente cuando guardas los cambios en la base de datos mediante SaveChanges(). 

Entity Framework valida los atributos decorados con Data Annotations antes de persistir los datos en la base de datos.

Otros artículos

Principio de Sustitución de Liskov (LSP) – SOLID explicado con ejemplos

¿Qué es el Principio de Sustitución de Liskov? Imaginá que tenés un control remoto universal diseñado para funcionar con cualquier televisor. Si un nuevo modelo de TV no responde a los mismos comandos, el control deja de ser útil. El Principio de Sustitución de Liskov es como una garantía de que cualquier 'televisor' (o clase derivada) va a funcionar correctamente con el 'control remoto' (o clase base). El Principio de Sustitución de Liskov ( LSP ) es el tercer principio de SOLID , representado por la letra L y establece que: Los objetos de una clase derivada deben poder sustituir a los objetos de su clase base sin afectar el comportamiento correcto del programa. En otras palabras, si una clase hija hereda de una clase padre, cualquier instancia de la clase hija debería poder usarse en lugar de una instancia de la clase padre sin alterar la funcionalidad esperada. ¿Quién es Bárbara Liskov? Bárbara Liskov es una destacada científi...

Open/Closed Principle (OCP) – SOLID explicado con ejemplos

Continuando con el repaso de los principios de S.O.L.I.D. que inició en el hilo anterior - si no lo viste hacé click acá  Principio de Responsabilidad Única (SRP) - vamos a ver el segundo en orden de aparición: Principio de Abierto/Cerrado (OCP por sus siglas en inglés). Definición Formal El principio OCP (Open/Closed Principle) establece que el código de una clase o un módulo debe estar abierto para la extensión, pero cerrado para la modificación. Esto significa que no se deben realizar cambios en el código existente cuando se requiere alterar alguna funcionalidad. En lugar de modificar el código existente, se debe crear una nueva implementación que extienda la funcionalidad. La única excepción a esto son los arreglos de bugs, donde está permitido modificar el código existente. Si se desea introducir una nueva funcionalidad, como la ordenación en un método existente, en lugar de modificar el código, se crearía una nueva implementación q...

Evolución de ASP .NET: de Web Forms a .NET Core

La historia de ASP .NET  (Active Server Pages) se remonta a 1996, cuando Microsoft lanzó la primera versión de ASP como una solución para desarrollar páginas web dinámicas.  Esta tecnología fue pionera en su momento, permitiendo a los desarrolladores combinar HTML, scripts y componentes para crear aplicaciones web funcionales. Sin embargo, con el tiempo, las crecientes demandas del desarrollo web moderno hicieron evidente la necesidad de una evolución tecnológica.  Fue en 2002 cuando esta evolución dio un gran salto con la llegada de ASP .NET  Web Forms , marcando el inicio oficial de la nueva era de ASP .NET. Diseñada para facilitar la transición de los desarrolladores de aplicaciones de escritorio al mundo web, Web Forms adoptó un enfoque que emulaba la programación de escritorio e introdujo conceptos como el ViewState y eventos en el servidor . Aunque ASP .NET Web Forms trajo avances importantes, también mostró sus limitaciones con el ...

Principio de Responsabilidad Única (SRP) – SOLID explicado con ejemplos

Introducción a S.O.L.I.D En esta entrada, intentaremos abordar un nuevo ciclo de conceptos que tienen que ver sobre los principios SOLID , que son fundamentales en la programación orientada a objetos o POO . Estos principios fueron formulados, en principio, por Robert C. Martin , también conocido como " Uncle Bob ", con el objetivo de mejorar la mantenibilidad y escalabilidad del código de software. SOLID es un acrónimo que representa cinco principios de diseño: Single Responsibility Principle (SRP) – Principio de Responsabilidad Única Open/Closed Principle (OCP) – Principio de Abierto/Cerrado Liskov Substitution Principle (LSP ) – Principio de Sustitución de Liskov Interface Segregation Principle (ISP) – Principio de Segregación de Interfaces Dependency Inversion Principle (DIP) – Principio de Inversión de Dependencias Estos principios nos ayudan a crear software más ...

Roadmap para Desarrolladores Backend en .NET en 2025

El mundo del desarrollo backend está en constante evolución, y mantenerse actualizado con las mejores prácticas y tecnologías es clave para seguir siendo competitivo en el mercado. Si estás buscando una guía clara y estructurada para mejorar tus habilidades en . NET backend , el sitio roadmap.sh ofrece un excelente punto de partida. Para esta entrada vamos a explorar lo siguiente: ¿Qué es roadmap.sh y por qué es relevante? El roadmap backend para .NET en 2025 Tecnologías y habilidades esenciales para backend a considerar ¿Qué es roadmap.sh y quién lo creó? roadmap.sh es una plataforma ampliamente reconocida dentro de la comunidad de desarrolladores. Fue creada por Kamran Ahmed, un Google Developer Expert y contribuidor en múltiples proyectos de código abierto. Desde su lanzamiento, la plataforma ha crecido exponencialmente, acumulando más de 300,000 estrellas en GitHub y una comunidad activa de...

Principio de Inversión de Dependencia (DIP) – SOLID explicado con ejemplos

Estamos cerrando este ciclo de definiciones para SOLID , y en esta entrada vamos a dar un vistazo al último principio de la lista: DIP o Dependency Inversion Principle . El Principio de Inversión de Dependencia (DIP) establece que: Los módulos de alto nivel no deben depender de módulos de bajo nivel. Ambos deben depender de abstracciones. Las abstracciones no deben depender de los detalles. Los detalles deben depender de las abstracciones. El Problema de la Dependencia Directa Imaginate que estás construyendo una aplicación que envía notificaciones. Para empezar rápido, decidís crear un controlador que usa directamente un servicio de correo electrónico: public class NotificationController { private EmailNotificationService _service = new EmailNotificationService (); // Acá tenemos dependencia directa } Al principio, todo parece estar bien. El controlador puede enviar correos sin problema. Pero luego surge un requisito: ta...