我一直无法在ASP.NET Core Controller 中验证由Scaffold-DbContext命令生成的模型。
所需/最大长度属性配置全部在EF核心生成的上下文类的onModelCreating方法中。
protected override void OnModelCreating( ModelBuilder modelBuilder ) {
modelBuilder.Entity<ModelClass>( entity => {
entity.ToTable( "ModelClass", "schema" );
entity.Property( e => e.ModelClassCode )
.IsRequired()
.HasMaxLength( 30 );
我的 Controller 以JSON格式接收模型的数据,但是即使我发送无效数据,ModelState.IsValid始终返回true。
public IActionResult CreateModelClass( [FromBody]ModelClass modelClass ) {
// ModelState.IsValid always returns true here
我将ModelState.IsValid设置为false的唯一方法是将数据注释添加到模型类中。我想避免这种情况,因为运行scaffold命令将覆盖这些更改。
我在这里想念什么吗?有人可以指出我的例子吗?我所看到的与验证有关的都是使用数据注释。
最佳答案
如@Smit的注释中所述,您可以使用-DataAnnotations
命令中的Scaffold-DbContext
开关来生成带有正确验证注释的模型。
请在此处查看Scaffold-DbContext
的文档:https://docs.microsoft.com/en-us/ef/core/miscellaneous/cli/powershell
关于validation - ASP.NET和EF Core-对于由Scaffold-DbContext生成的模型,ModelState.IsValid始终返回true,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/41093419/