.NET MVC第四章、模型绑定获取表单数据

简介: .NET MVC第四章、模型绑定获取表单数据

模型绑定概述

模型绑定就是将浏览器发送的HTTP请求数据转换为.NET对象的过程。


模型绑定使得在控制器中可以直接获取视图、或URL传递来的数据,且这些数据可以自动转换为模型对象,以便调用。


模型绑定机制省略了常见Request.QueryString手动传值和类型转换的步骤,这样可以专注地处理模型对象。


获取值demo

获取方法1、参数获取


获取方法2、Request.QueryString["userName"]


控制器

public ActionResult Index(string pwd)
{
    ViewBag.userName = Request.QueryString["userName"];
    ViewBag.pwd = pwd;
    return View();
}

视图层


<h2>表单传值</h2>
<hr />
<form action="~/Test/Index" method="get">
    <p>账号<input type="text" name="userName" placeholder="请输入账号" /></p>
    <p>密码<input type="password" name="pwd" placeholder="请输入密码" /></p>
    <p><input type="submit" value="提交" class="btn btn-block btn-primary" /></p>
</form>
<hr />
@ViewBag.userName
<br />
@ViewBag.pwd

效果:

image.png



模型获取值

在Models下创建User.cs作为模型

image.png



创建Users对象


image.png


控制器


public ActionResult Index(Users users)
{
    ViewBag.userName = users.userName;
    ViewBag.pwd = users.pwd;
    return View();
}

视图层不变。


效果:

image.png



共计尝试了三种获取值的方法,还有一种获取文件的方法。


文件获取,必须使用post接收

控制器


[HttpPost]
public ActionResult GetImg(HttpPostedFileBase file)
{
    string fileName = file.FileName;
    ViewBag.fileName = "上传文件的名称:"+fileName;
    // 保存到测试目录
    file.SaveAs("D:\\"+fileName);
    return Redirect("~/Test/Index");
}

视图层


表单提交图片,必须是post提交,并且添加enctype="multipart/form-data"上传图片

<h2>获取图片</h2>
<hr />
<form action="~/Test/GetImg" method="post" enctype="multipart/form-data">
    <p><input type="file" name="file"/></p>
    <p><input type="submit" value="提交" class="btn btn-block btn-primary" /></p>
</form>

上传图片

image.png



D盘查看文件:

image.png



可空int参数

在“ Index(string gname, int? gid)”方法的参数声明中,gid参数需要设定为int?类型,这种类型称为“可空 int类型”。 当文本框输入的内容包含“非int类型”或“空数据”时,模型绑定器将无法正确实现int类型转换,默认的绑定随之失效。为避免出现这类异常,需要为控制器的相关参数设定“可空类型”或“参数默认值”。


控制器


public ActionResult Index(string userName,int? age=2)
{
    ViewBag.userName = userName;
    ViewBag.age = age;
    return View();
}

视图层


<h2>int?</h2>
<hr />
<form action="~/Test/Index" method="get">
    <p><input type="text" name="userName" placeholder="请输入用户名" /></p>
    <p><input type="text" name="age" placeholder="请输入用年龄" /></p>
    <p><input type="submit" value="提交" class="btn btn-block btn-primary" /></p>
</form>
<hr />
@ViewBag.userName
<br />
@ViewBag.age

未传参效果:

image.png



传参效果


image.png


文件上传

控制器


[HttpPost]
public ActionResult GetImg(HttpPostedFileBase file)
{
    //文件名
    string fileName = file.FileName;
    //文件后缀需要引入using System.IO;
    string Ext = Path.GetExtension(fileName);
    //获取服务路径
    string serverPath = Server.MapPath("/");
    //生成随机不重复图片名称UUID
    string uuid = System.Guid.NewGuid().ToString("N");
    //拼接保存位置
    string saveUrl=serverPath + uuid + Ext;
    // 保存到测试目录
    file.SaveAs(saveUrl);
    TempData["saveUrl"] = uuid+Ext;
    return Redirect("~/Test/Index");
}


视图层


<h2>获取图片</h2>
<hr />
<form action="~/Test/GetImg" method="post" enctype="multipart/form-data">
    <p><input type="file" name="file"/></p>
    <p><input type="submit" value="提交" class="btn btn-block btn-primary" /></p>
</form>
<hr/>
显示图片路径:
@TempData["saveUrl"]
<hr/>
<img src="~/@TempData["saveUrl"]" width="500"/>

效果:

image.png



保存位置

image.png



图片这里必须要会,很重要。

相关文章
|
23天前
|
开发框架 前端开发 .NET
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
ASP.NET MVC WebApi 接口返回 JOSN 日期格式化 date format
29 0
|
23天前
|
开发框架 前端开发 安全
ASP.NET MVC 如何使用 Form Authentication?
ASP.NET MVC 如何使用 Form Authentication?
|
24天前
|
人工智能 文字识别
通义语音AI技术问题之LCB-net模型对幻灯片中文本信息的使用如何解决
通义语音AI技术问题之LCB-net模型对幻灯片中文本信息的使用如何解决
12 0
|
27天前
|
开发框架 .NET
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
Asp.Net Core 使用X.PagedList.Mvc.Core分页 & 搜索
76 0
|
3月前
|
Web App开发 前端开发 Java
基于Spring3 MVC实现基于HTML form表单文件上传
基于Spring3 MVC实现基于HTML form表单文件上传
39 7
基于Spring3 MVC实现基于HTML form表单文件上传
|
3月前
|
设计模式 前端开发 安全
理解最常用的MVC分层模型及其变种
【6月更文挑战第24天】 本文介绍架构模式如MVC、MVVM和MVP是解决软件结构问题的通用方案。。每种模式有其优缺点,适用场景不同。
97 0
理解最常用的MVC分层模型及其变种
|
3月前
|
机器学习/深度学习 JSON 测试技术
CNN依旧能战:nnU-Net团队新研究揭示医学图像分割的验证误区,设定先进的验证标准与基线模型
在3D医学图像分割领域,尽管出现了多种新架构和方法,但大多未能超越2018年nnU-Net基准。研究发现,许多新方法的优越性未经严格验证,揭示了验证方法的不严谨性。作者通过系统基准测试评估了CNN、Transformer和Mamba等方法,强调了配置和硬件资源的重要性,并更新了nnU-Net基线以适应不同条件。论文呼吁加强科学验证,以确保真实性能提升。通过nnU-Net的变体和新方法的比较,显示经典CNN方法在某些情况下仍优于理论上的先进方法。研究提供了新的标准化基线模型,以促进更严谨的性能评估。
110 0
|
3月前
|
SQL 开发框架 .NET
(20)ASP.NET Core EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性)
(20)ASP.NET Core EF创建模型(必需属性和可选属性、最大长度、并发标记、阴影属性)
|
3月前
|
安全 前端开发 测试技术
安全开发-PHP应用&模版引用&Smarty渲染&MVC模型&数据联动&RCE安全&TP框架&路由访问&对象操作&内置过滤绕过&核心漏洞
安全开发-PHP应用&模版引用&Smarty渲染&MVC模型&数据联动&RCE安全&TP框架&路由访问&对象操作&内置过滤绕过&核心漏洞
|
4月前
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
141 0
下一篇
DDNS