Blazor WASM Forms Validation
Blazor
32 Articles
In this article, let's learn about how to validate the data collected using forms in Blazor WASM application.
Note: If you have not done so already, I recommend you read the article on Blazor Wasm Forms.
Table of Contents
- Why Validation?
- Introducing DataAnnotationsValidator
- Displaying Error Messages
- Fluent Validations
- Summary
Why Validation?
Validation is the act of checking the validity of data. It is a very important part of the form validation process. We should always validate the user data before submitting it to the server. Validation can be from simple data format validation to complex business validations. Simple data format validations like checking email format can be done in client side while checking email uniquness in system can be done in server side. Processing the raw data can sometime allow an attacker to exploit our systems. Hence it is always recommended to validate the data before processing.
Introducing DataAnnotationsValidator
The DataAnnotationsValidator is the standard validator type in Blazor. Adding this component within an EditForm component will enable form validation based on .NET Data Annotation attributes
Code Sample - Data Annotations Validation Demo
Displaying Error Messages
Validation error messages can be displayed to the user in two ways. We can add a ValidationSummary to show a comprehensive list of all errors in the form. We can also use the ValidationMessage component to display error messages for a specific input on the form. These components are not mutually exclusive, so it is possible to use both at the same time. The ValidationSummary component can simply be dropped into an EditForm in our mark-up; no additional parameters are required at all.
As the ValidationMessage component displays error messages for a single field, it requires us to specify the identity of the field.
In the above demo when you submit the form with invalid value, you can see two error messages getting displayed. The error message above text box is from ValidationSummary and the error message below the text box is from ValidationMessage.
Fluent Validations
FluentValidation is a popular validation library for .NET by Jeremy Skinner. It has some advantages over .NET's built-in DataAnnotations validation system, such as a richer set of rules, easier configuration, and easier extensibility.
FluentValidation does not provide integration with Blazor out of the box. Let's learn how to make Fluent Validation integrate and work nicely with Blazor. Lets start by using the same ExampleModel and configure and validate using Fluent Validation using below steps.
- Install Nuget Package - FluentValidation
- Add the below FluentValidator<TValidator> to your project. This code snippet updated version of Fluent Validatoe originally created by Steve Sanderson. I have added original source link in the snippet.
- Now Create a YourModelClassValidator : AbstractValidator<YourModelClass>
- Finally add <FluentValidator TValidator="YourModelClassValidator" />
Code Sample - Fluent Validator
Code Sample - Fluent Validator Demo
Note that I use the above method in my production apps and it works well as of now. But there are several third party libraries you can use to do this as mentioned in Fluent Validation official site:
- Blazored.FluentValidation
- Blazor-Validation
- Accelist.FluentValidation.Blazor
- vNext.BlazorComponents.FluentValidation
Summary
In this article, we learn't how to validate data collected using Forms in blazor application using various techniques like DataAnnotationsValidator using .NET's built in Data Annotation Validation Attrinutes and FluentValidator using FluentValidation Library and how to display the error messages and feedback to user. DataAnnotations Validator is suffice for simple scenarios but for complex scenarios, I'd recommend FluentValidator.