Binding Fluent Validation to an HTML View - C# ASP.Net MVC Core
data:image/s3,"s3://crabby-images/cc68c/cc68cbc1ec6b136d27d6e947348086b5464a7f7b" alt="Binding Fluent Validation to an HTML View - C# ASP.Net MVC Core"
Strongly-Typed Data Model Validation
Previously I discussed using the FluentValidation library to implement strongly-typed data model validation in C# .Net Core. Today we’re going to look at injecting that validation to an HTML view in C# ASP.Net MVC Core, making use of the standard ModelState syntax in MVC.
Nuget Packages
You’ll need to pull in a copy of FluentValidation and FluentValidation.AspNetCore from Nuget.
Let’s Code…
First of all we need a basic view model with some fields to validate.
data:image/s3,"s3://crabby-images/f9481/f9481f11d8e7501e61c245f570425448463866f7" alt="C# ASP.Net MVC Core - Fluent Validation Data Model"
C# ASP.Net MVC Core - Fluent Validation Data Model
Abstract Validator Inheritance
Now that we have a data model, we can create a validation class which inherits from AbstractValidator. In this case I’ve separated the FirstName field from the technical data about our new user for cleanliness.
data:image/s3,"s3://crabby-images/b4462/b4462cfdaa9882f44de6e7107dd3689b9f4513d6" alt="C# ASP.Net MVC Core - Fluent Validation Abstract Validator"
C# ASP.Net MVC Core - Fluent Validation Abstract Validator
data:image/s3,"s3://crabby-images/b0aa4/b0aa47eef6c12c11b346774ccde099bc87608e85" alt="C# ASP.Net MVC Core - Fluent Validation View Model Validator"
C# ASP.Net MVC Core - Fluent Validation View Model Validator
Startup Configuration
Next we need to inject the validator class into our platform at startup.
data:image/s3,"s3://crabby-images/6f394/6f39499e20fb9f261382a56e3e414af87c72eb94" alt="C# ASP.Net MVC Core - Fluent Validation Configure Services"
C# ASP.Net MVC Core - Fluent Validation Configure Services
HTML View
Let’s put together a simple form with a post back for our data model.
data:image/s3,"s3://crabby-images/4f414/4f41423073aef59b7f37f9438e0af0c503836725" alt="C# ASP.Net MVC Core - Fluent Validation HTML View"
C# ASP.Net MVC Core - Fluent Validation HTML View
data:image/s3,"s3://crabby-images/7e768/7e76862d0802ef3c7cb5b6b0995768da6699f5a1" alt="C# ASP.Net MVC Core - Fluent Validation HTML"
C# ASP.Net MVC Core - Fluent Validation HTML
Now let’s submit a blank version of our page data to the controller.
data:image/s3,"s3://crabby-images/48398/48398f9fa22027b057f6549e002591a804d57eac" alt="C# ASP.Net MVC Core - Fluent Validation HTML Errors"
C# ASP.Net MVC Core - Fluent Validation HTML Errors
As you can see, our fluent validation has kicked in with very little else required in terms of implementation. Let’s amend the data slightly and see how our validation errors change.
data:image/s3,"s3://crabby-images/12fc6/12fc6c2863809257e9461beaf9c142c0a4206e10" alt="C# ASP.Net MVC Core - Fluent Validation HTML Different Errors"
C# ASP.Net MVC Core - Fluent Validation HTML Different Errors
Finally, let’s submit a fully valid post back
data:image/s3,"s3://crabby-images/04dfe/04dfef76310d815bbdb06472098d25e0afbc2cb9" alt="C# ASP.Net MVC Core - Fluent Validation HTML Valid"
C# ASP.Net MVC Core - Fluent Validation HTML Valid
…and see how our fluent validation responds?
data:image/s3,"s3://crabby-images/70832/70832a353aa85007b3cf02adf66e7a52e66a9883" alt="C# ASP.Net MVC Core - Fluent Validation HTML Successful Validation"
C# ASP.Net MVC Core - Fluent Validation HTML Successful Validation
…Success! As mentioned before, FluentValidation provides a much cleaner method of carrying out strongly typed data model validation than the traditional DataAnnotations namespace.
Enjoy!