DataAnnotation doğrulama özniteliği için Int veya Number DataType


111

MVC3 projemde, futbol / futbol / hokey / ... spor oyunu için skor tahminini saklıyorum. Tahmin sınıfımın özelliklerinden biri şuna benzer:

[Range(0, 15, ErrorMessage = "Can only be between 0 .. 15")]
[StringLength(2, ErrorMessage = "Max 2 digits")]
[Remote("PredictionOK", "Predict", ErrorMessage = "Prediction can only be a number in range 0 .. 15")]
public int? HomeTeamPrediction { get; set; }

Şimdi, intbenim durumumda bir veri türü için hata mesajını da değiştirmem gerekiyor . Kullanılan bazı varsayılanlar vardır - "HomeTeamPrediction alanı bir sayı olmalıdır." Bu hata mesajını nasıl değiştireceğinizin bir yolunu bulmanız gerekiyor. Bu doğrulama mesajı aynı zamanda Uzaktan doğrulama için bir tahmin alıyor gibi görünüyor.

[DataType]Özniteliği denedim ama bu system.componentmodel.dataannotations.datatypenumaralandırmada düz bir sayı gibi görünmüyor .

Yanıtlar:


221

Herhangi bir numara doğrulaması için, gereksinimlerinize göre farklı farklı aralık doğrulaması kullanmanız gerekir:

Tamsayı için

[Range(0, int.MaxValue, ErrorMessage = "Please enter valid integer Number")]

şamandıra için

[Range(0, float.MaxValue, ErrorMessage = "Please enter valid float Number")]

çift ​​için

[Range(0, double.MaxValue, ErrorMessage = "Please enter valid doubleNumber")]

4
Bu benim bağlamımda benim için işe yaramadı. Kullanıcı "asdf", [Aralık (typeof (ondalık), "0", "9999.99", ErrorMessage = "{0} değeri {1} ile {2} arasında olmalıdır")] girerse bir istisna atın. Ancak, [Aralık (typeof (ondalık), "0.1", "9999.99", ErrorMessage = "{0} için değer {1} ile {2} arasında olmalıdır")] yaparsam, hata mesajı düzgün çalışacaktır. 0 vs 0.1, mantıklı değil. belki böcek?
meffect

1
Bu "tamsayı" doğrulaması, tamsayı olmayan değerleri geçerli kabul eder (ör. 0.3)
kevinpo

77

Şu normal ifadelerden birini deneyin:

// for numbers that need to start with a zero
[RegularExpression("([0-9]+)")] 


// for numbers that begin from 1
[RegularExpression("([1-9][0-9]*)")] 

umarım yardımcı olur: D


13
Daha basit bir yol yok mu?
Şuna

3
Ne yazık ki hayır. Her zaman kendi doğrulama özniteliğinizi yazabilirsiniz.
Goran Žuri

2
Bu, dizeleri kapsadığı için daha iyi bir çözümdür. int.MaxValuesadece şu tarihe kadar kapsar2.147.483.647
Christian Gollhardt

19

Veri ek açıklamasında normal ifade kullanın

[RegularExpression("([0-9]+)", ErrorMessage = "Please enter valid Number")]
public int MaxJsonLength { get; set; }

2
Özelliğin int değil string olması koşuluyla, bu soru bağlamında iyi çalışıyor gibi görünüyor.
Paul

1
Normal ifadenin etrafında neden parantez var? Sadece olabilir [0-9]+mi?
polkduran

5
public class IsNumericAttribute : ValidationAttribute
{
    protected override ValidationResult IsValid(object value, ValidationContext validationContext)
    {
        if (value != null)
        {
            decimal val;
            var isNumeric = decimal.TryParse(value.ToString(), out val);

            if (!isNumeric)
            {                   
                return new ValidationResult("Must be numeric");                    
            }
        }

        return ValidationResult.Success;
    }
}

5

Bu özelliği deneyin:

public class NumericAttribute : ValidationAttribute, IClientValidatable {

    public override bool IsValid(object value) {
        return value.ToString().All(c => (c >= '0' && c <= '9') || c == '-' || c == ' ');
    }


    public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context) {
        var rule = new ModelClientValidationRule
        {
            ErrorMessage = FormatErrorMessage(metadata.DisplayName),
            ValidationType = "numeric"
        };
        yield return rule;
    }
}

Ayrıca, doğrulayıcı eklentisine özniteliği kaydetmeniz gerekir:

if($.validator){
     $.validator.unobtrusive.adapters.add(
        'numeric', [], function (options) {
            options.rules['numeric'] = options.params;
            options.messages['numeric'] = options.message;
        }
    );
}

0

neredeyse on yıl geçti, ancak konu Asp.Net Core 2.2 için de geçerli.

data-val-numberGiriş alanına mesajdaki kullanım yerelleştirmesini ekleyerek yönettim:

<input asp-for="Age" data-val-number="@_localize["Please enter a valid number."]"/>

0

ASP.NET Core 3.1

Bu, benim özelliğim uygulamamdır, sunucu tarafında ve diğer herhangi bir özellik gibi özel bir hata mesajıyla göze batmayan jquery doğrulamasında çalışır:

Öznitelik:

  [AttributeUsage(AttributeTargets.Property, AllowMultiple = false, Inherited = false)]
    public class MustBeIntegerAttribute : ValidationAttribute, IClientModelValidator
    {
        public void AddValidation(ClientModelValidationContext context)
        {
            MergeAttribute(context.Attributes, "data-val", "true");
            var errorMsg = FormatErrorMessage(context.ModelMetadata.GetDisplayName());
            MergeAttribute(context.Attributes, "data-val-mustbeinteger", errorMsg);
        }

        public override bool IsValid(object value)
        {
            return int.TryParse(value?.ToString() ?? "", out int newVal);
        }

        private bool MergeAttribute(
              IDictionary<string, string> attributes,
              string key,
              string value)
        {
            if (attributes.ContainsKey(key))
            {
                return false;
            }
            attributes.Add(key, value);
            return true;
        }
    }

İstemci tarafı mantığı:

$.validator.addMethod("mustbeinteger",
    function (value, element, parameters) {
        return !isNaN(parseInt(value)) && isFinite(value);
    });

$.validator.unobtrusive.adapters.add("mustbeinteger", [], function (options) {
    options.rules.mustbeinteger = {};
    options.messages["mustbeinteger"] = options.message;
});

Ve son olarak Kullanım:

 [MustBeInteger(ErrorMessage = "You must provide a valid number")]
 public int SomeNumber { get; set; }
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.