热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

ASP.NETCore的ModelBinding来源与校验的介绍

ASP.NETCoreMVC的ModelBinding会将HTTPRequest数据,以映射的方式对应到参数中。基本上跟ASP.NETMVC差不多,但能Binding的来源更多了一

ASP.NET Core MVC的Model Binding会将HTTP Request数据,以映射的方式对应到参数中。基本上跟ASP.NET MVC差不多,但能Binding的来源更多了一些。
本篇将介绍ASP.NET Core的Model Binding。

Model Binding

要接收Client 传送来的数据,可以通过Action 的参数接收,如下:

1

2

3

4

5

6

7

8

9

10

11

12

using Microsoft.AspNetCore.Mvc;

 

namespace MyWebsite.Controllers

{

    public class HomeController : Controller

    {

        public IActionResult Index(int id)

        {

            return Content($"id: {id}");

        }

    }

}

id就是从HTTP Request的内容被Binding的Model参数。
预设的Model Binding会从HTTP Request的三个地方取值(优先顺序由上到下):

  • Form
    透过HTTP POST的form取值。如下图:

ASP.NET Core的Model Binding来源与校验的介绍

  • Route
    是通过MVC Route URL取值。
    如:http://localhost:5000/Home/Index/2id取出的值就会是2。
  • Query
    是通过URL Query参数取值。
    如:http://localhost:5000/Home/Index?id=1id取出的值就会是1。

如果三者都传入的话,会依照优先顺序取值Form > Route > Query

Binding Attributes

除了预设的三种Binding 来源外,还可以通过Model Binding Attributes 从HTTP Request 的其他数据中Binding。有以下6 种:

  • [FromHeader]
    从HTTP Header取值。
  • [FromForm]
    通过HTTP POST的form取值。
  • [FromRoute]
    是通过MVC Route URL取值。
  • [FromQuery]
    是通过URL Query参数取值。
  • [FromBody]
    从HTTP Body取值,通常用于取JSON, XML。
    ASP.NET Core MVC预设的序列化是使用JSON,如果要传XML格式做Model Binding的话,要在MVC服务加入XmlSerializerFormatters,如下:

    Startup.cs

1

2

3

4

5

6

// ...

public void ConfigureServices(IServiceCollection services)

{

    services.AddMvc()

            .AddXmlSerializerFormatters();

}

  • [FromServices]
    这个比较特别,不是从HTTP Request取值,而是从DI容器取值。
    DI预设是使用Constructor Injection,但Controller可能会因为每个Action用到不一样的Service导致很多参数,所以也可以在Action注入Service。

范例程序

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

// ...

public class HomeController : Controller

{

    public IActionResult FirstSample(

        [FromHeader]string header,

        [FromForm]string form,

        [FromRoute]string id,

        [FromQuery]string query)

    {

        return Content($"header: {header}, form: {form}, id: {id}, query: {query}");

    }

     

    public IActionResult DISample([FromServices] ILogger logger)

    {

        return Content($"logger is null: {logger == null}.");

    }

 

    public IActionResult BodySample([FromBody]UserModel model)

    {

        return Ok(model);

    }

}

 

// ...

public class UserModel

{

    public int Id { getset; }       

    public string Name { getset; }       

    public string Email { getset; }       

    public string PhoneNumber { getset; }       

    public string Address { getset; }

}

输出结果

FirstSample输出结果:

ASP.NET Core的Model Binding来源与校验的介绍

DISample输出结果:
http://localhost:5000/Home/DISample

1

logger is null: False.

BodySample输出结果:

  • JSON
    ASP.NET Core的Model Binding来源与校验的介绍
  • XML
    ASP.NET Core的Model Binding来源与校验的介绍

Model 验证

Model Binding 也可以顺便帮忙验证字段数据,只要在字段的属性上面带上Validation Attributes,如下:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

using System.ComponentModel.DataAnnotations;

// ...

public class UserModel

{

    [Required]

    public int Id { getset; }

 

    [RegularExpression(@"\w+")]

    [StringLength(20, MinimumLength = 4)]

    public string Name { getset; }

 

    [EmailAddress]

    public string Email { getset; }

 

    [Phone]

    public string PhoneNumber { getset; }

 

    [StringLength(200)]

    public string Address { getset; }

}

然后在Action 加上判断:

Controllers\HomeController.cs

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

using Microsoft.AspNetCore.Mvc;

 

namespace MyWebsite.Controllers

{

    public class HomeController : Controller

    {

        // ...

        public IActionResult BodySample([FromBody]UserModel model)

        {

            // 由于 Id 是 int 类型,int 默认为 0

            // 虽然带上了 [Required],但不是 null 所以算是有值。

            if (model.Id <1)

            {

                ModelState.AddModelError("Id""Id not exist");

            }

            if (ModelState.IsValid)

            {

                return Ok(model);

            }

            return BadRequest(ModelState);

        }

    }

}

输入错误数据的输出结果:

ASP.NET Core的Model Binding来源与校验的介绍

.NET Core提供了很多的Validation Attributes,可以参考官网:System.ComponentModel.DataAnnotations

自定义Validation Attributes

如果.NET Core提供的Validation Attributes不够用还可以自己做。
例如上述范例的数据模型多了生日字段,需要验证年龄:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

38

39

40

41

42

43

using System;

using System.ComponentModel.DataAnnotations;

 

namespace MyWebsite.Attributes

{

    public class AgeCheckAttribute : ValidationAttribute

    {

        public int MinimumAge { getprivate set; }

        public int MaximumAge { getprivate set; }

 

        public AgeCheckAttribute(int minimumAge, int maximumAge)

        {

            MinimumAge = minimumAge;

            MaximumAge = maximumAge;

        }

 

        protected override ValidationResult IsValid(object value, ValidationContext validationContext)

        {

            var date = Convert.ToDateTime(value);

 

            if (date.AddYears(MinimumAge) > DateTime.Today

                || date.AddYears(MaximumAge)

            {

                return new ValidationResult(GetErrorMessage(validationContext));

            }

 

            return ValidationResult.Success;

        }

 

        private string GetErrorMessage(ValidationContext validationContext)

        {

            // 有帶 ErrorMessage 的话优先使用

            // [AgeCheck(18, 120, ErrorMessage="xxx")]

            if (!string.IsNullOrEmpty(this.ErrorMessage))

            {

                return this.ErrorMessage;

            }

 

            // 自定义错误信息

            return $"{validationContext.DisplayName} can't be in future";

        }

    }

}

参考

Overview of ASP.NET Core MVC 
Introduction to model validation in ASP.NET Core MVC 
ASP.NET CORE 2.0 MVC MODEL BINDING 
ASP.NET CORE 2.0 MVC MODEL VALIDATION

 

a learning project for net core 2: https://github.com/SnailDev/SnailDev.NETCore2Learning

 


推荐阅读
  • Startup 类配置服务和应用的请求管道。Startup类ASP.NETCore应用使用 Startup 类,按照约定命名为 Startup。 Startup 类:可选择性地包括 ... [详细]
  • 本文详细介绍超文本标记语言(HTML)的基本概念与语法结构。HTML是构建网页的核心语言,通过标记标签描述页面内容,帮助开发者创建结构化、语义化的Web页面。 ... [详细]
  • 哈密顿回路问题旨在寻找一个简单回路,该回路包含图中的每个顶点。本文将介绍如何判断给定的路径是否构成哈密顿回路。 ... [详细]
  • 算法题解析:最短无序连续子数组
    本题探讨如何通过单调栈的方法,找到一个数组中最短的需要排序的连续子数组。通过正向和反向遍历,分别使用单调递增栈和单调递减栈来确定边界索引,从而定位出最小的无序子数组。 ... [详细]
  • 本问题探讨了在特定条件下排列儿童队伍的方法数量。题目要求计算满足条件的队伍排列总数,并使用递推算法和大数处理技术来解决这一问题。 ... [详细]
  • 深入解析SpringMVC核心组件:DispatcherServlet的工作原理
    本文详细探讨了SpringMVC的核心组件——DispatcherServlet的运作机制,旨在帮助有一定Java和Spring基础的开发人员理解HTTP请求是如何被映射到Controller并执行的。文章将解答以下问题:1. HTTP请求如何映射到Controller;2. Controller是如何被执行的。 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • 深入解析Spring Boot自动配置机制
    本文旨在深入探讨Spring Boot的自动配置机制,特别是如何利用配置文件进行有效的设置。通过实例分析,如Http编码自动配置,我们将揭示配置项的具体作用及其背后的实现逻辑。 ... [详细]
  • 自己用过的一些比较有用的css3新属性【HTML】
    web前端|html教程自己用过的一些比较用的css3新属性web前端-html教程css3刚推出不久,虽然大多数的css3属性在很多流行的浏览器中不支持,但我个人觉得还是要尽量开 ... [详细]
  • 反向投影技术主要用于在大型输入图像中定位特定的小型模板图像。通过直方图对比,它能够识别出最匹配的区域或点,从而确定模板图像在输入图像中的位置。 ... [详细]
  • ssm框架整合及工程分层1.先创建一个新的project1.1配置pom.xml ... [详细]
  • SpringMVC RestTemplate的几种请求调用(转)
    SpringMVCRestTemplate的几种请求调用(转),Go语言社区,Golang程序员人脉社 ... [详细]
  • 在寻找轻量级Ruby Web框架的过程中,您可能会遇到Sinatra和Ramaze。两者都以简洁、轻便著称,但它们之间存在一些关键区别。本文将探讨这些差异,并提供详细的分析,帮助您做出最佳选择。 ... [详细]
  • springMVC JRS303验证 ... [详细]
  • 本文档汇总了Python编程的基础与高级面试题目,涵盖语言特性、数据结构、算法以及Web开发等多个方面,旨在帮助开发者全面掌握Python核心知识。 ... [详细]
author-avatar
猫儿爱妞_591
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有