ASP.NET MVC 重点教程一周年版 第十回 请求Controller

简介: 其实我们通常遇到的请求方式无非get/post,但是有很多Web开发人员仍然对二者分不清。     get即通过URL中的QueryString向服务器端传值的方式,它的数据是可见的,可post则是通过一个postdata包向服务器传值,post方式可以传送更多数据(如上传文件),也更安全(如登录)。

    其实我们通常遇到的请求方式无非get/post,但是有很多Web开发人员仍然对二者分不清。

    get即通过URL中的QueryString向服务器端传值的方式,它的数据是可见的,可post则是通过一个postdata包向服务器传值,post方式可以传送更多数据(如上传文件),也更安全(如登录)。

    本文将演示各种通过客户端页面(即最终生成的页面)向Controller提交请求以及在Controller中接受的方式。

约定

    本文所有的示例都将是演示一个登录过程,但并不关注判断过程,所以判断方面仅做简单的IF操作。

    而提交的实体我们新建一个Account类。

image

它的内容如下:

   1: /// <summary>
   2:  /// 用户账户的实体类
   3:  /// </summary>
   4:  public class Account {
   5:      /// <summary>
   6:      /// 用户名
   7:      /// </summary>
   8:      public string UserName { get; set; }
   9:      /// <summary>
  10:      /// 密码
  11:      /// </summary>
  12:      public string Password { get; set; }
  13:  }

文中大多数示例使用了Account类,但并不是所有的示例都使用了Account。

在文中我们并不关注提交信息的页面的Controller,仅关注处理信息的Controller。

而Controller中存在这样一个方法,用于辅助判断:

   1: /// <summary>
   2: /// 一个辅助判断的方法
   3: /// </summary>
   4: /// <param name="userName">用户名</param>
   5: /// <param name="password">密码</param>
   6: /// <returns></returns>
   7: string AreEquals(string userName,string password)
   8: {
   9:     return (userName.ToLower() == "admin" && password == "123456").ToString();
  10: }

以Post提交的数据来看传递

    之所以这里先说Post是因为相对于Get方式来说Post的情况更全,说明了Post的情况Get也就差不多了。

View:

   1: <%using (Html.BeginRouteForm(new { controller = "home", action = "process" })) {%>
   2: <p>
   3:     <label>用户名:</label><%=Html.TextBox("username") %></p>
   4: <p>
   5:     <label>密码:</label><%=Html.TextBox("password") %></p>
   6: <p>
   7:     <input type="submit" /></p>
   8: <%
   9:     }%>

image

1.从最基本的开始,使用Request获取提交的信息

 

 

   1: /// <summary>
   2: /// 处理请求的Action 
   3: /// </summary>
   4: /// <returns></returns>
   5: public ActionResult Process()
   6: {
   7:     return Content(
   8:         AreEquals(Request.Form["username"], Request.Form["password"])
   9:         );
  10: }

    这个无多解释,通过Request.Form来获取表单提交我想是最基本的方法之一,如果您对这种方法不了解的话,那么就说明您的ASP.NET基础有待提交,可以查看ASP.NET五大对象的相关文章。

2.通过Action参数提交

相比之下这个可能更加漂亮些。

   1: /// <summary>
   2: /// 处理请求的Action 
   3: /// </summary>
   4: /// <param name="userName">这两个参数务必与表单中的名称一致</param>
   5: /// <param name="password"></param>
   6: /// <returns></returns>
   7: public ActionResult Process(string userName, string password)
   8: {
   9:     return Content(
  10:         AreEquals(userName, password)
  11:         );
  12: }

3.UpdateModel来获取传递

   1: /// <summary>
   2: /// 处理请求的Action 
   3: /// </summary>
   4: /// <returns></returns>
   5: public ActionResult Process()
   6: {
   7:     var a = new Account();
   8:     UpdateModel(a);//确定a包含Password及UserName这两个属性即可,否则抛出异常
   9:     return Content(
  10:         AreEquals(a.UserName, a.Password)
  11:         );
  12: }

当然我们这里很容易出现异常所以可以使用另一个方法来替代,TryUpdateModel:

   1: /// <summary>
   2: /// 处理请求的Action 
   3: /// </summary>
   4: /// <returns></returns>
   5: public ActionResult Process()
   6: {
   7:     var a = new Account();
   8:     //这样就可以在没有成功转换时使用另一种处理方式
   9:     return Content(
  10:         TryUpdateModel(a))?AreEquals(a.UserName, a.Password):bool.FalseString
  11:         );
  12: }

上面这种UpdateModel的方法已经很简单了,可是ASP.NET MVC为我们提供了更简单的方式:

4.使用绑定

   1: /// <summary>
   2: /// 处理请求的Action 
   3: /// </summary>
   4: /// <returns></returns>
   5: public ActionResult Process(Account a)
   6: {
   7:     return Content(
   8:         AreEquals(a.UserName, a.Password)
   9:         );
  10: }

就是这么简单

 

可能存在的问题

我们在提交表单时可能有多个Account对象,这种情况下我们应该怎么办呢。

请看下面:

image

View:

   1: <%using (Html.BeginRouteForm(new { controller = "home", action = "process" })) {%>
   2: <p>
   3:     <label>用户名1:</label><%=Html.TextBox("a.username") %></p>
   4: <p>
   5:     <label>密码1:</label><%=Html.TextBox("a.password") %></p>
   6:        <p>
   7:     <label>用户名2:</label><%=Html.TextBox("b.username") %></p>
   8: <p>
   9:     <label>密码2:</label><%=Html.TextBox("b.password") %></p>
  10: <p>
  11:     <input type="submit" /></p>
  12: <%
  13:     }%>

注意这里的表单元素的Name、

下面是处理的Action代码:

   1: /// <summary>
   2:  /// 处理请求的Action 
   3:  /// </summary>
   4:  /// <returns></returns>
   5:  public ActionResult Process(Account a ,Account b)
   6:  {
   7:   //处理代码
   8:      return View();
   9:  }

这就一切OK了

目录
相关文章
|
开发框架 前端开发 JavaScript
ASP.NET Web Pages - 教程
ASP.NET Web Pages 是一种用于创建动态网页的开发模式,采用HTML、CSS、JavaScript 和服务器脚本。本教程聚焦于Web Pages,介绍如何使用Razor语法结合服务器端代码与前端技术,以及利用WebMatrix工具进行开发。适合初学者入门ASP.NET。
|
开发框架 搜索推荐 算法
一个包含了 50+ C#/.NET编程技巧实战练习教程
一个包含了 50+ C#/.NET编程技巧实战练习教程
503 18
|
缓存 算法 安全
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
精选10款C#/.NET开发必备类库(含使用教程),工作效率提升利器!
649 12
|
监控 前端开发 API
一款基于 .NET MVC 框架开发、功能全面的MES系统
一款基于 .NET MVC 框架开发、功能全面的MES系统
612 5
|
开发框架 NoSQL MongoDB
C#/.NET/.NET Core开发实战教程集合
C#/.NET/.NET Core开发实战教程集合
308 1
|
开发框架 前端开发 JavaScript
ASP.NET MVC 教程
ASP.NET 是一个使用 HTML、CSS、JavaScript 和服务器脚本创建网页和网站的开发框架。
356 7
|
SQL 关系型数据库 数据库
七天.NET 8操作SQLite入门到实战详细教程(选型、开发、发布、部署)
七天.NET 8操作SQLite入门到实战详细教程(选型、开发、发布、部署)
411 2
|
存储 NoSQL API
.NET NoSQL 嵌入式数据库 LiteDB 使用教程
.NET NoSQL 嵌入式数据库 LiteDB 使用教程~
717 0
|
存储 开发框架 前端开发
ASP.NET MVC 迅速集成 SignalR
ASP.NET MVC 迅速集成 SignalR
347 0
|
开发框架 前端开发 .NET
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
ASP.NET CORE 3.1 MVC“指定的网络名不再可用\企图在不存在的网络连接上进行操作”的问题解决过程
698 0