ASP.NET Core教程【二】从保存数据看Razor Page的特有属性与服务端验证

前文索引: ASP.NET Core教程【一】关于Razor Page的知识

在layout.cshtml文件中,我们可以看到如下代码:

<a asp-page="/Index" class="navbar-brand">RazorPagesMovie</a>

这段代码中用到asp-page这样的一个特有属性,这是razor page特有的,

这是一个锚点属性,它的值将被编译到a标签的href属性上;

跟多的时候,我们会像下面这样使用锚点属性

<a asp-controller="Speaker" asp-action="Detail">Speaker Detail</a>

 编译过之后,上面的链接是这样的

<a href="/Speaker/Detail">Speaker Detail</a>

 这很好的把action和controller分开了

下面我们看看把实体提交到数据库的代码(cshtml.cs文件中)

using Microsoft.AspNetCore.Mvc;using Microsoft.AspNetCore.Mvc.RazorPages;using RazorPagesMovie.Models;using System.Threading.Tasks;namespace RazorPagesMovie.Pages.Movies{    public class CreateModel : PageModel    {        private readonly RazorPagesMovie.Models.MovieContext _context;        public CreateModel(RazorPagesMovie.Models.MovieContext context)        {            _context = context;        }        public IActionResult OnGet()        {            return Page();        }        [BindProperty]        public Movie Movie { get; set; }        public async Task<IActionResult> OnPostAsync()        {            if (!ModelState.IsValid)            {                return Page();            }            _context.Movie.Add(Movie);            await _context.SaveChangesAsync();            return RedirectToPage("./Index");        }    }}

一般我们在OnGet方法中初始化页面需要的状态数据;

这个页面没有状态数据需要初始化,所以我们就不用做任何事情

Page()方法返回一个PageResult对象,该对象负责渲染这个页面;

Movie属性被标记了BindProperty标记,说明它是一个“模型绑定”对象;

当表单提交过来的时候,asp.net core负责把表单提交的数据,绑定到这个对象上;

表单提交之后,OnPostAsync方法被执行,

如果提交的数据,在绑定到Movie对象的过程中,产生了异常,那么Page方法会被重新执行,等于刷新了一遍页面;

大部分数据验证的工作是在客户端通过JS完成的

但是我们也不能完全依赖JS(防止模拟浏览器,恶意提交)

客户端提交上来了一个表单域是一个日期字符串,在绑定到对象属性的时候,可能产生异常,如果产生了异常,ModelState.IsValid就非真。

接下来看看页面代码:

@page@model RazorPagesMovie.Pages.Movies.CreateModel@{    ViewData["Title"] = "Create";}<h2>Create</h2><h4>Movie</h4><hr /><div class="row">    <div class="col-md-4">        <form method="post">            <div asp-validation-summary="ModelOnly" class="text-danger"></div>            <div class="form-group">                <label asp-for="Movie.Title" class="control-label"></label>                <input asp-for="Movie.Title" class="form-control" />                <span asp-validation-for="Movie.Title" class="text-danger"></span>            </div>            <div class="form-group">                <label asp-for="Movie.ReleaseDate" class="control-label"></label>                <input asp-for="Movie.ReleaseDate" class="form-control" />                <span asp-validation-for="Movie.ReleaseDate" class="text-danger"></span>            </div>            <div class="form-group">                <label asp-for="Movie.Genre" class="control-label"></label>                <input asp-for="Movie.Genre" class="form-control" />                <span asp-validation-for="Movie.Genre" class="text-danger"></span>            </div>            <div class="form-group">                <label asp-for="Movie.Price" class="control-label"></label>                <input asp-for="Movie.Price" class="form-control" />                <span asp-validation-for="Movie.Price" class="text-danger"></span>            </div>            <div class="form-group">                <input type="submit" value="Create" class="btn btn-default" />            </div>        </form>    </div></div><div>    <a asp-page="Index">Back to List</a></div>@section Scripts {    @{await Html.RenderPartialAsync("_ValidationScriptsPartial");}}

 <form method="post">在razor page中也是一个特殊标签,

这个标签会自动添加一个反伪造令牌,用于防止跨站脚本攻击;

asp-validation-summary和asp-validation-for都是用于显示客户端验证的失败信息的

<label asp-for="Movie.Title" class="control-label"></label>会输出包含标题和for属性的label标签;

<input asp-for="Movie.Title" class="form-control" />会使用模型里的DataAnnotations属性,生成能作用域jQuery Validation插件的input标签;

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Danny的专栏

机房收费系统——将MSHFlexGrid控件中的数据导出到Excel

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/huyuyang6688/article/...

1332
来自专栏谢易成的专栏

Vue服务端渲染之cookie,user-agent获取

Vue服务端渲染有个参数runInNewContext,之前我们这个参数一直设置为true,这样可以全局获取到直出的context。

1.1K2
来自专栏智能大石头

手工调试自定义控件各主要方法执行顺序(分运行时和设计时)

继承TextBox,override各个方法,分别下断点调试。 ctor为构造函数 在构造函数中,通过代码: this.Text = (new Random(D...

21310
来自专栏技术墨客

React学习(最终篇)—— 高阶应用:高阶组件(HOCs)

高阶组件(higher-order components:以下简称HOC或HOC组件)是一个React组件复用的高级技巧。HOCs本身并不是React的API接...

2744
来自专栏青青天空树

MFC--响应鼠标和键盘操作

  一.  理解鼠标事件.之前对鼠标事件的认识仅仅局限于处理控件的单击与双击事件.但实际鼠标的操作包含很多.这里将以一个画图的小程序讲解对鼠标的响应.

1171
来自专栏肖洒的博客

Python网络数据采集

有人说编程语言就是宗教,不同语言的设计哲学不同,行为方式各异,“非我族类,其心必异”,但本着美好生活、快乐修行的初衷,我们对所有语言都时刻保持敬畏之心,尊重信仰...

3983
来自专栏强仔仔

利用js实现输入框动态提示信息

为了提高和用户的交互性,现在的输入框往往都采用输入信息自动提示的功能,类似于百度输入框中的提示功能。 设计思路是:在输入框input的组件下面放置一个div,这...

6916
来自专栏木子墨的前端日常

react-navigation 使用笔记 持续更新中

React-Navigation是目前React-Native官方推荐的导航组件,代替了原用的Navigator。最近开始接触,做个笔记

1224
来自专栏hbbliyong

C#基础知识回顾--委托事件

在上一篇看到他我一下子就悟了---委托,被人狂喷。说写的太空,没有什么内容之类的。所以准备在这里重写下,不过还是按着以前的方式尽量简单的写。这里我们以打篮球为...

3524
来自专栏IT开发技术与工作效率

VBA登录抓取网络数据

2704

扫码关注云+社区

领取腾讯云代金券