相关文章推荐
谦逊的苦瓜  ·  第三届全国文明校园,名单来了!广西36所学校 ...·  1 月前    · 
乐观的桔子  ·  Sharing ext4 to ...·  2 月前    · 
文武双全的钥匙扣  ·  龙膜后羿15(avsp ...·  4 月前    · 
另类的墨镜  ·  口腔溃疡喝水溶c100有用吗-抖音·  11 月前    · 
淡定的小刀  ·  JSON神器之jq使用指南指北 - ...·  1 年前    · 
Code  ›  ASP.NET Core教程【二】从保存数据看Razor Page的特有属性与服务端验证开发者社区
https://cloud.tencent.com/developer/article/1019468?areaSource=106005.6
深沉的刺猬
2 年前
作者头像
liulun
0 篇文章

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

前往专栏
腾讯云
开发者社区
文档 意见反馈 控制台
首页
学习
活动
专区
工具
TVP
文章/答案/技术大牛
发布
首页
学习
活动
专区
工具
TVP
返回腾讯云官网
社区首页 > 专栏 > liulun > ASP.NET Core教程【二】从保存数据看Razor Page的特有属性与服务端验证

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

作者头像
liulun
发布 于 2018-01-12 16:04:53
900 0
发布 于 2018-01-12 16:04:53
举报

前文索引: 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标签;

点击展开阅读全文
本文参与 腾讯云自媒体分享计划 ,分享自作者个人站点/博客。
原始发表:2017-11-27 , 如有侵权请联系 cloudcommunity@tencent.com 删除
asp.net
html

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划 ,欢迎热爱写作的你一起参与!

asp.net
html
评论
登录 后参与评论
0 条评论
热度
最新
登录 后参与评论
关于作者
liulun
0
文章
0
累计阅读量
0
获赞
前往专栏
切换旧版
领券
  • 社区

    • 专栏文章
    • 阅读清单
    • 互动问答
    • 技术沙龙
    • 技术视频
    • 团队主页
    • 腾讯云TI平台
  • 活动

    • 自媒体分享计划
    • 邀请作者入驻
    • 自荐上首页
    • 技术竞赛
  • 资源

    • 技术周刊
    • 社区标签
    • 开发者手册
    • 开发者实验室
  • 关于

    • 社区规范
    • 免责声明
    • 联系我们
    • 友情链接

腾讯云开发者

扫码关注腾讯云开发者

扫码关注腾讯云开发者

领取腾讯云代金券

热门产品

  • 域名注册
  • 云服务器
  • 区块链服务
  • 消息队列
  • 网络加速
  • 云数据库
  • 域名解析
  • 云存储
  • 视频直播

热门推荐

  • 人脸识别
  • 腾讯会议
  • 企业云
  • CDN加速
  • 视频通话
  • 图像分析
  • MySQL 数据库
  • SSL 证书
  • 语音识别

更多推荐

  • 数据安全
  • 负载均衡
  • 短信
  • 文字识别
  • 云点播
  • 商标注册
  • 小程序开发
  • 网站监控
  • 数据迁移

Copyright © 2013 - 2023 Tencent Cloud. All Rights Reserved. 腾讯云 版权所有

深圳市腾讯计算机系统有限公司 ICP备案/许可证号: 粤B2-20090059 深公网安备号 44030502008569

腾讯云计算(北京)有限责任公司 京ICP证150476号 | 京ICP备11018762号 | 京公网安备号11010802020287

问题归档 专栏文章 快讯文章归档 关键词归档 开发者手册归档 开发者手册 Section 归档

Copyright © 2013 - 2023 Tencent Cloud.

All Rights Reserved. 腾讯云 版权所有

登录 后参与评论
 
推荐文章
谦逊的苦瓜  ·  第三届全国文明校园,名单来了!广西36所学校获得全国文明校园称号 - 教育工作动态 - 广西壮族自治区教育厅网站
1 月前
乐观的桔子  ·  Sharing ext4 to multiple initiators with iSCSI | TrueNAS Community
2 月前
文武双全的钥匙扣  ·  龙膜后羿15(avsp 15)隔热膜性能参数|龙膜玻璃膜型号及价格表|龙膜汽车贴膜价格表-龙膜
4 月前
另类的墨镜  ·  口腔溃疡喝水溶c100有用吗-抖音
11 月前
淡定的小刀  ·  JSON神器之jq使用指南指北 - sunsky303 - 博客园
1 年前
今天看啥   ·   Py中国   ·   codingpro   ·   小百科   ·   link之家   ·   卧龙AI搜索
删除内容请联系邮箱 2879853325@qq.com
Code - 代码工具平台
© 2024 ~ 沪ICP备11025650号