热门标签 | 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

 


推荐阅读
  • 本文详细介绍了如何使用 Yii2 的 GridView 组件在列表页面实现数据的直接编辑功能。通过具体的代码示例和步骤,帮助开发者快速掌握这一实用技巧。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 使用 Azure Service Principal 和 Microsoft Graph API 获取 AAD 用户列表
    本文介绍了一段通用代码示例,该代码不仅能够操作 Azure Active Directory (AAD),还可以通过 Azure Service Principal 的授权访问和管理 Azure 订阅资源。Azure 的架构可以分为两个层级:AAD 和 Subscription。 ... [详细]
  • 根据最新发布的《互联网人才趋势报告》,尽管大量IT从业者已转向Python开发,但随着人工智能和大数据领域的迅猛发展,仍存在巨大的人才缺口。本文将详细介绍如何使用Python编写一个简单的爬虫程序,并提供完整的代码示例。 ... [详细]
  • 本文探讨了在UC浏览器中调用分享面板后,图片无法正常显示的问题,并提供了详细的解决方法和代码示例。 ... [详细]
  • PHP 过滤器详解
    本文深入探讨了 PHP 中的过滤器机制,包括常见的 $_SERVER 变量、filter_has_var() 函数、filter_id() 函数、filter_input() 函数及其数组形式、filter_list() 函数以及 filter_var() 和其数组形式。同时,详细介绍了各种过滤器的用途和用法。 ... [详细]
  • PHP 编程疑难解析与知识点汇总
    本文详细解答了 PHP 编程中的常见问题,并提供了丰富的代码示例和解决方案,帮助开发者更好地理解和应用 PHP 知识。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 解决PHP与MySQL连接时出现500错误的方法
    本文详细探讨了当使用PHP连接MySQL数据库时遇到500内部服务器错误的多种解决方案,提供了详尽的操作步骤和专业建议。无论是初学者还是有经验的开发者,都能从中受益。 ... [详细]
  • 在前两篇文章中,我们探讨了 ControllerDescriptor 和 ActionDescriptor 这两个描述对象,分别对应控制器和操作方法。本文将基于 MVC3 源码进一步分析 ParameterDescriptor,即用于描述 Action 方法参数的对象,并详细介绍其工作原理。 ... [详细]
  • 5G至4G空闲态移动TAU流程解析
    本文详细解析了用户从5G网络移动到4G网络时,在空闲态下触发的跟踪区更新(TAU)流程。通过N26接口实现无缝迁移,确保用户体验不受影响。 ... [详细]
  • 本文探讨了领域驱动设计(DDD)的核心概念、应用场景及其实现方式,详细介绍了其在企业级软件开发中的优势和挑战。通过对比事务脚本与领域模型,展示了DDD如何提升系统的可维护性和扩展性。 ... [详细]
  • 本文深入探讨了HTTP请求和响应对象的使用,详细介绍了如何通过响应对象向客户端发送数据、处理中文乱码问题以及常见的HTTP状态码。此外,还涵盖了文件下载、请求重定向、请求转发等高级功能。 ... [详细]
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社区 版权所有