在Asp.Net核心中为Enumerable添加每个元素的验证,可以通过自定义扩展方法来实现。下面是一个示例代码:
using System;
using System.Collections.Generic;
using System.ComponentModel.DataAnnotations;
namespace YourNamespace
{
public static class EnumerableExtensions
{
public static IEnumerable<T> Validate<T>(this IEnumerable<T> enumerable)
{
foreach (var item in enumerable)
{
var context = new ValidationContext(item);
var results = new List<ValidationResult>();
bool isValid = Validator.TryValidateObject(item, context, results, true);
if (!isValid)
{
foreach (var validationResult in results)
{
Console.WriteLine(validationResult.ErrorMessage);
}
}
yield return item;
}
}
}
}
上述代码定义了一个名为Validate
的扩展方法,该方法接受一个IEnumerable<T>
类型的参数,并对其中的每个元素进行验证。验证使用了System.ComponentModel.DataAnnotations
命名空间中的特性来定义验证规则。
使用该扩展方法的示例代码如下:
using System;
using System.Collections.Generic;
namespace YourNamespace
{
public class Person
{
public string Name { get; set; }
[Range(18, 99, ErrorMessage = "Age must be between 18 and 99.")]
public int Age { get; set; }
}
public class Program
{
public static void Main(string[] args)
{
var people = new List<Person>
{
new Person { Name = "John", Age = 25 },
new Person { Name = "Jane", Age = 15 },
new Person { Name = "Mike", Age = 35 }
};
foreach (var person in people.Validate())
{
Console.WriteLine($"{person.Name} is valid.");
}
}
}
}
上述示例代码定义了一个Person
类,其中Age
属性使用了Range
特性来限制年龄的范围。在Main
方法中,我们创建了一个List<Person>
对象,并使用Validate
扩展方法对其中的每个元素进行验证。如果验证失败,将输出错误消息。
这是一个简单的示例,你可以根据实际需求扩展验证逻辑和错误处理。对于Asp.Net核心中的Enumerable验证,你可以根据具体的业务需求来定义验证规则,并使用相应的特性来进行验证。
腾讯云相关产品和产品介绍链接地址:
领取专属 10元无门槛券
手把手带您无忧上云