Pergunta

Eu uso Ninject, MVC4, AutomApper e FluentValidation colados.

Escrevi um validador para o meu modelo de visualização e escrevi um validador reutilizável que deve ser chamado no validador do modelo View.

A questão é que, quando eu publico o formulário, a substituição do validato não é chamada no validador do modelo de view, para que o validador reutilizável também não seja chamado; portanto, no final, o ModelResult é válido ... (causando uma exceção ao escrever a entidade para o banco de dados) ...

O estranho é que, quando adicionei uma regra para uma das propriedades, o formulário está sendo bem validado.

public class RequiredSourceViewModelValidator : AbstractValidator<RequiredSourceViewModel>
    {
        public RequiredSourceViewModelValidator()
        {
            Mapper.CreateMap<RequiredSourceViewModel, Source>();
        }

        public override FluentValidation.Results.ValidationResult Validate(RequiredSourceViewModel requiredSourceViewModel)
        {
            var validator = new SourceValidator();

            var source = Mapper.Map<RequiredSourceViewModel, Source>(requiredSourceViewModel);

            return validator.Validate(source);
        }
    }


public class SourceValidator : AbstractValidator<Source>
    {
        public SourceValidator()
        {
            RuleFor(s => s.Name)
                .NotEmpty()
                    .WithMessage("Naam mag niet leeg zijn.")
                .Length(1, 100)
                    .WithMessage("Naam mag niet langer zijn dan 100 karakters.");

            RuleFor(s => s.Url)
                .NotEmpty()
                    .WithMessage("Url mag niet leeg zijn.")
                 .Must(BeAValidUrl)
                    .WithMessage("Url is niet geldig.")
                .Length(1, 100)
                    .WithMessage("Url mag niet langer zijn dan 100 karakters.");
        }

        private bool BeAValidUrl(string url)
        {
            if (url == null)
            {
                return true;
            }

            var regex = new Regex(@"^http(s)?://([\w-]+.)+[\w-]+(/[\w- ./?%&=])?$");
            return regex.IsMatch(url);
        }
    }

public class Source : IEntity
    {
        /// <summary>
        /// Gets or sets the primary key of the source.
        /// </summary>
        public int Id { get; set; }

        /// <summary>
        /// Gets or sets the name of the source.
        /// </summary>
        public string Name { get; set; }

        /// <summary>
        /// Gets or sets the url of the source.
        /// </summary>
        public string Url { get; set; }

        /// <summary>
        /// Gets or sets the ordinal of the source.
        /// </summary>
        /// <value>
        /// The ordinal of the source.
        /// </value>
        public int Ordinal { get; set; }

        public int? GameId { get; set; }
    }

Oque pode estar errado aqui ?

Foi útil?

Solução

Você está substituindo a sobrecarga errada. Você precisa substituir o método Validate pela assinatura: public virtual ValidationResult Validate(ValidationContext<T> context) porque esse método será chamado durante a validação do MVC:

public override ValidationResult Validate(
      ValidationContext<RequiredSourceViewModel> context)
{
     var validator = new SourceValidator();

     var source = 
         Mapper.Map<RequiredSourceViewModel, Source>(context.InstanceToValidate);

     return validator.Validate(source);
 }

A outra sobrecarga é usada apenas se você chamar manualmente validar como validator.Validate(object).

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top