首页 > 其他分享 >数据校验

数据校验

时间:2024-08-01 23:28:02浏览次数:6  
标签:LoginRequest app FluentValidation 校验 规则 数据 public

来到人间蹉跎二十年,只为你回眸一笑。 --zhu
前言
输入的是垃圾,输出也必然是垃圾,有多少安全问题隐藏在请求的数据中,所以永远不能相信来自用户端的输入。
对请求数据的合法性进行校验,不仅有助于提升用户界面的友好性,而且有助于提高后台程序的安全性和稳定性。
ASP.NET Core 主要通过内置的 DataAnnotations 实现对数据进行校验,DataAnnotations 是一组属性类,用于为模型类的属性添加验证规则,如必填、最大长度、正则表达式等,使用时非常方便。

实现
1、创建 Login 操作方法的请求参数类 LoginRequest

using System.ComponentModel.DataAnnotations;

public class LoginRequest
{
	// 直接对类属性设置数据内置检验
	[Required]
	[EmailAddress]
	[RegularExpression("^.*@(qq|163)\\.com$", ErrorMessage = "只支持QQ和163邮箱")]
	public string Email { get; set; }

	[Required]
	[StringLength(10, MinimumLength = 3)]
	public string Password { get; set; }

	[Compare(nameof(Password), ErrorMessage = "两次密码必须一致")]
	public string PasswordConfirm { get; set; }
}

2、打开登录请求控制器,编写 Login API

using Microsoft.AspNetCore.Mvc;

namespace DatavalidSample.Controllers
{
	[ApiController]
	[Route("[controller]/[action]")]
	public class TestController : ControllerBase
	{
		// 执行时,自动对 LoginRequest 进行数据校验
		[HttpPost]
		public ActionResult Login(LoginRequest req)
		{
			return Ok(req);
		}
	}
}

内置数据校验总结
总的来说,ASP.NET Core 内置数据校验功能适用于大多数简单的数据校验需求,能够提高开发效率和代码可维护性,如果想更多更强功能,第三方框架校验数据更具优势,比如FluentValidation。

FluentValidation优势

  1. FluentValidation 使用 Fluent 方式配置校验规则,通过链式调用方法,使得编写校验规则变得非常直观和易于理解,可以轻松地构建复杂的校验规则。
  2. FluentValidation 内置更多的校验规则,可以满足各种复杂的数据校验需求。
  3. FluentValidation 更方便扩展自定义规则,实现校验逻辑的重用,提高代码的可维护性和复用性。
  4. FluentValidation 与 ASP.NET MVC、ASP.NET Core、Web API 等框架无缝集成,数据校验和验证可以轻松地与应用程序的其他部分进行交互。
  5. FluentValidation 支持根据具体的校验规则和场景来定义更加友好和具体的错误消息,提高用户体验。
  6. FluentValidation 的校验规则更容易进行单元测试。

实现
1、引用Nuget 包

FluentValidation.AspNetCore

2、创建 Login 操作方法的请求参数模型类 LoginRequest

// LoginRequest 类只是一个普通的 C# 类,
// 没有标注任何的 Attribute 或者实现任何的接口,
// 它的唯一责任就是传递数据
public record LoginRequest(string Email, string Password, string PasswordConfirm);

3、编写继承自AbstractValidator的数据校验类

using FluentValidation;

// 数据校验类要继承自 AbstractValidator
// 通过 AbstractValidator 的泛型参数指定对哪个类进行校验
public class LoginRequestValidator: AbstractValidator<LoginRequest>
{
	// 校验规则写到校验类的构造方法中
	public LoginRequestValidator()
	{
		// 通过RuleFor来指定要对哪个属性进行校验
		// 多个校验规则可以采用链式调用的写法
		// 每个需要校验的属性对应一组RuleFor调用
		RuleFor(x => x.Email)
			.NotNull()
			.EmailAddress()
			// 在Must方法中编写自定义校验规则,
			.Must(v => v.EndsWith("@qq.com") || v.EndsWith("@163.com"))
			// 通过WithMessage方法自定义报错信息,
			// WithMessage方法设置的报错信息只作用于它之前的那个校验规则
			.WithMessage("只支持QQ和163邮箱");

		RuleFor(x => x.Password)
			.NotNull()
			.Length(3, 10).WithMessage("密码长度必须介于3到10之间")
			.Equal(x => x.PasswordConfirm).WithMessage("两次密码必须一致");
	}
}

4、Program.cs,注册 FluentValidation 服务

using FluentValidation;
using FluentValidation.AspNetCore;
using System.Reflection;

var builder = WebApplication.CreateBuilder(args);

// Add services to the container.

builder.Services.AddControllers();
// Learn more about configuring Swagger/OpenAPI at https://aka.ms/aspnetcore/swashbuckle
builder.Services.AddEndpointsApiExplorer();
builder.Services.AddSwaggerGen();

Assembly assembly = Assembly.GetExecutingAssembly();
builder.Services.AddFluentValidationAutoValidation()
	.AddFluentValidationClientsideAdapters()
	.AddValidatorsFromAssembly(assembly);
var app = builder.Build();

// Configure the HTTP request pipeline.
if (app.Environment.IsDevelopment())
{
	app.UseSwagger();
	app.UseSwaggerUI();
}

app.UseHttpsRedirection();

app.UseAuthorization();

app.MapControllers();

app.Run();	

5、编写 Login API

using Microsoft.AspNetCore.Mvc;

namespace FluentValidationSample.Controllers
{
	[ApiController]
	[Route("[controller]/[action]")]
	public class TestController : ControllerBase
	{
		[HttpPost]
		public ActionResult Login(LoginRequest req)
		{
			return Ok();
		}
	}
}

总结

  1. FluentValidation 把数据校验的规则写到单独的数据校验类中,这样模型类和数据校验类各司其职,符合 “单一职责原则”
  2. 在 FluentValidation 中编写自定义校验代码更加简单
  3. FluentValidation 和 .NET Core 内置的校验方式是可以共存的,也就是可以一部分校验规则用 FluentValidation 写,另一部分校验规则用 .NET Core 内置的校验方式写(不建议)。

标签:LoginRequest,app,FluentValidation,校验,规则,数据,public
From: https://www.cnblogs.com/zhusichen/p/18337704

相关文章

  • 【数据结构】排序
    目录1.前言2.排序的概念及引用2.1排序的概念2.2常见的排序算法 3.常见排序算法的实现3.1插入排序3.1.1基本思想 3.1.2直接插入排序 3.1.3希尔排序(缩小增量排序)3.2选择排序3.2.1基本思想3.2.2直接选择排序3.2.3堆排序3.3交换排序3.3.1基本思想3.3.2冒泡排......
  • 高性能数据库架构:掌握主从复制技术
    一、数据库主从复制的概念数据库主从复制是一种常用的技术,用于提高数据库系统的可用性、性能和可靠性。通过将数据从主数据库(master)复制到从数据库(slave),可以实现数据的备份、负载均衡和高可用性。以下是对数据库主从复制的详细解释及其在MySQL中的具体实现步骤和示例。1.......
  • MyCAT数据库中间件:让你的数据库无缝扩展!
    什么是MyCATMyCAT是一个开源的数据库中间件系统,设计用于支持分布式数据库环境。它被广泛用于大数据和高并发的场景中,作为传统关系数据库(如MySQL)的扩展,以提高性能和扩展能力。MyCAT提供了数据库分片、读写分离、负载均衡、以及跨库的事务支持等功能。MyCAT的详细解释及其......
  • 【Mysql】Docker下Mysql8数据备份与恢复
    目录【Mysql】Docker下Mysql8数据备份与恢复1创建Mysql容器2连接Mysql3Binlog检查3.1检查是否开启3.2mysql5.73.3mysql84备份数据库4.1容器里执行备份4.2宿主机执行备份4.3参数说明5定时备份!/bin/bash按shift+:输入wq【Mysql】Docker下Mysql8数据备份与恢复1......
  • 数据结构经典测试题5
    1.intmain(){chararr[2][4];strcpy(arr[0],"you");strcpy(arr[1],"me");arr[0][3]='&';printf("%s\n",arr);return0;}上述代码输出结果是什么呢?A:you&meB:youC:meD:err答案为A因为arr是一个2行4列的二维数组,每一行可以存放最多三个......
  • RocketMq 拉取数据流程源码分析
    从一个问题开始1、一个boker,一个主题,两个队列,一个消费者组,一个消费节点,此时两个队列是落在一个消费节点上,请问这个消费节点是如何拉取数据的?需要明确关键对象之间的关系。关键对象有:1、RebalancePushImpl---》队列经过相关负载均衡算法,最终哪些队列落在当前节点上2、DefaultM......
  • Redis和Mysql如何保持数据一致性
    一般情况下,Redis是用来实现应用和数据库之间读操作得缓存层,主要目的是减少数据库IO,还可以提升数据的IO性能。当应用程序需要去读取某个数据时,会首先尝试去Redis里面加载,如果命中就直接返回,如果没有命中,就去从数据库中查询,查询到数据之后再把这个数据缓存到Redis里。 如果一......
  • 【数据科学】Pandas数据库中的Series&DataFrame
    前言前文再续,书接上一回,前两回讲到了Pandas的Series和DataFrame,今天我们使用jupyternotebook来进一步聊聊series和dataframe之间的关系。之前的文章中,我们了解到series和dataframe之间可以相互转换,看完这篇文章,相信你对它们之间的关系会有进一步的了解。正文importdata首......
  • 深圳大学-数据科学导论实验-python数据探索
    实验目的与要求掌握python编程基础。掌握数据探索基本操作。实验环境WindowsPyCharm实验数据salaries.csv"","rank","discipline","yrs.since.phd","yrs.service","sex","salary""1","Prof","B",......
  • 顺序消费rocketMQ(FIFO先进先出)和小技巧 取模运算的周期性特征来将数据分组。
    20240801一、顺序消费MQ(FIFO先进先出)介绍二、一个小技巧,对于取模运算,用来在几以前进行随机选取,取模运算的周期性特征来将数据分组,使用场景对于取模会重复问题一、顺序消费MQ(FIFO先进先出)介绍发送顺序和消费顺序保持一致默认情况消费方式是并发模式,会导致消息乱序......