Validações – A maneira fácil de produzir regras de negócio na sua UI

Validadores tornam fácil  a tarefa de validar dados na UI,mas você sabia como é fácil criar seu próprio controle validador?


Validators são controles excelentes,mas os que vem com ASP.NET são , digamos,limitados.Para a maioria da lógica de negócio,desenvolvedores usam ou CustomValidators (que permite você inserir seu próprio código de validação),ou criam suas próprias validações do inicio ao fim.A resposta correta é geralmente criar seu próprio Validador para chamar o código de validação na sua aplicação.

Eu tinha um cliente que deveria coletar informações de endereço de diversas páginas. Adicionar todos os controles necessários e códigos para essa páginas era realmente entediante,eu considerei então criar um “Endereço user control”, que eu poderia arrastar para qualquer página.Porém,user controls só podem ser usados em um projeto.
Ao invés disso então eu criei um novo Validator o “EnderecoValidator” e coloquei na
ToolBox,assim eu pude usar em outros projetos também.

Eu trouxe o enderecovalidator pra esse exemplo porque ele suporta validar múltiplos controles (não somente o controle enderecoRua,mas também os controles da cidade,do estado, e do país)que poderiam ser text Boxes  ou qualquer outro tipo de controle de lista(dropdown-list, radiobutton list).

Criando o controle

Criar um controle de validação é relativamente simples:Crie um novo projeto,e na aba Web,escolha ASP.NET server control(eu dei o nome de “PHValidator”).Com o projeto criado mude o nome da classe ServerControl1.cs para o nome que você que dar para o controle(eu usei enderecoValidator), a classe herdará da classe BaseValidator.Você também precisa mudar o nome,do controle no atributo ToolBoxData que aparece na declaração da classe.

using System;
using System.ComponentModel;
using System.Web.UI;
using System.Web.UI.WebControls;
namespace PHVValidators
{
[DefaultProperty(“ControlToValidate”)]
[ToolboxData(“<{0}:EnderecoValidator runat=server>
</{0}:EnderecoValidator>”)]
public class AddressValidator :
System.Web.UI.WebControls.BaseValidator
{

Tudo que você precisa adicionar para o baseValidator, é um teste para validar dados e qualquer propriedade adicional requirida para suportar seu código de validação.

Vamos ver primeiramente as propriedades.Para elas,eu preciso de alguns campos para armazenar os nomes dos controles que contém parte do endereço.Eu também preciso de algumas propriedades para capturar e armazenar os dados.Como essas propriedades devem receber o nome dos controles presentes em cada página,eu gostaria de ter a propriedade na janela de propriedades(property window),mostrada como uma drop-list de controles presentes na página.Isso é fácil de fazer:eu só adicionei o TypeConverterAttribute para a propriedade,passando o tipo de ValidadorControlConverter.Aqui um exemplo de propriedade para armazenar o nome do controle que tem o nome da cidade.

string cityId = “”;

[TypeConverterAttribute(typeof(ValidatedControlConverter))] _
string CityId
{
get
{
return cityId;
}
set
{
cityId = value;
}
}

Validando os dados

O único método da classe BaseValidator que você precisa reescrever,é o EvaluaterIsValid e retornar true ou false,dependendo do resultado de seu teste.Para pegar esses valores dos controles da páginas,chame o método,GetControlValidationValue passando o nome do controle que você quer.Esse código recupera o valor do controle cujo nome foi passado na propriedade CityId e retorna false para indicar que o teste falhou e o controle está vazio.

protected override bool EvaluateIsValid()
{
string CityValue = this.GetControlValidationValue(this.CityId);
if (CityValue == “”)
{
return false;
}
return true;
}

Na vida real,você provavelmente vai chamar métodos de validação na sua camada intermediária de negócios para checar seus dados.

Pra testar seu validator , adicione um projeto web para o projeto atual do seu validatorControl.Seu novo validador aparecerá no topo da toolbox – você pode arrasta-lo para a página ,mudar sua propriedades e debugar seu código.Se você fizer alguma mudança no seu ValidatorControl,você precisa dar um rebuild na sua solution,apagar o controle da tela,e arrasta-lo novamente.