asp.net.mvc 中form表单提交控制器的2种方法和控制器接收页面提交数据的4种方法
MVC中表单form是怎样提交? 控制器Controller是怎样接收的?
1、.cshtml 页面form提交
(1)普通方式的的提交
(2)特殊方式提交
2、控制器处理表单数据的四种方法
方法1:使用传统的Request请求数据
方法2:Action参数名与表单元素name值一一对应
方法3:从MVC封装的FormCollection容器中读取
方法4:使用实体作为Action参数传入,前提是提交的表单元素名称与实体属性名称一一对应
控制器源码
using MvcStudy.Models;
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
using System.Web.Mvc;
namespace MvcStudy.Controllers
{
public class LoginController : Controller
{
public ActionResult Index() {
return View();
}
public ActionResult Main() {
return View();
}
//1、.cshtml页面的form请求
//<form action="Login/index" method="post"></form>
//2、控制器处理表单提交方式的四种方法
////方法1:使用传统的Request请求数据
//[HttpPost]
//public ActionResult GetUserMsg()
//{
// string usercode = Request.Form["UserCode"];
// string userpwd = Request.Form["UserPwd"];
// if(usercode != "admin" || userpwd != "admin"){
// return RedirectToAction("../Home/error");
// }
// return RedirectToAction("main");
//}
////方法2:Action参数名与表单元素name值一一对应
//[HttpPost]
//public ActionResult GetUserMsg(string UserCode, string UserPwd)
//{
// string usercode = UserCode;
// string userpwd = UserPwd;
// if(usercode != "admin" || userpwd != "admin"){
// return RedirectToAction("../Home/error");
// }
// return RedirectToAction("main");
//}
////方法3:从MVC封装的FormCollection容器中读取
//[HttpPost]
//public ActionResult GetUserMsg(FormCollection form)
//{
// string usercode = form["UserCode"];
// string userpwd = form["UserPwd"];
// if (usercode != "admin" || userpwd != "admin")
// {
// return RedirectToAction("../Home/error");
// }
// return RedirectToAction("main");
//}
//方法4:使用实体作为Action参数传入,前提是提交的表单元素名称与实体属性名称一一对应
[HttpPost]
public ActionResult GetUserMsg(SysUser user)
{
string usercode = user.UserCode;
string userpwd = user.UserPwd;
if (usercode != "admin" || userpwd != "admin")
{
return RedirectToAction("../Home/error");
}
return RedirectToAction("main");
}
}
}
注意:RedirectToAction("main")是重定向你要登录的页面,RedirectToAction("error")则是错误提示页面
实体model类 SysUser
using System;
using System.Collections.Generic;
using System.Linq;
using System.Web;
namespace MvcStudy.Models
{
public class SysUser
{
public string UserCode { get; set; }
public string UserPwd { get; set; }
public SysUser() { }
public SysUser(string usercode,string userpwd) {
usercode = this.UserCode;
userpwd = this.UserPwd;
}
}
}
登录页面的效果如图
登录成功页面
登录失败页面
注意:登录失败时,也可以重定向在原先的登录页面
asp.net.mvc 中form表单提交控制器的2种方法和控制器接收页面提交数据的4种方法的更多相关文章
- MVC中Form表单的提交
概述 Web页面进行Form表单提交是数据提交的一种,在MVC中Form表单提交到服务器.服务端接受Form表单的方式有多种,如果一个Form有2个submit按钮,那后台如何判断是哪个按钮提交的数据 ...
- form表单中控件较多,加载完成后切换页面都很慢的解决方法
form表单中控件较多,加载完成后点击都很慢,为什么?我一页面中form表单里面上百个控件(如input.select.radio.checkbox等),还有一些js脚本,加载速度还可以,都能全部显示 ...
- from表单实现无跳转上传文件,接收页面后台数据。
本文基于我刚写的http://www.cnblogs.com/iwang5566/p/6287529.html进行了简单的扩展,实现页面无跳转表单数据提交,并接收后台返回的数据. 下载好,上一篇文章d ...
- from表单实现无跳转上传文件,接收页面后台数据
实现无跳转发送表单数据.文件,并能接收后台返回的数据. 主要技术要点: 1.form表单添加target属性,指定一个iframme的name:form表单提交后在iframe内嵌窗口接受响应,主页面 ...
- mvc中form表单提交的几种形式
第一种方式:submit 按钮 提交 <form action="MyDemand" method="post"> <span>关键字: ...
- ASP.NET MVC 与Form表单交互
一,Form包含文件类(单选文件) <form id="ImgForm" method="POST" enctype="multipart/fo ...
- MVC中处理表单提交的方式(Ajax+Jquery)
MVC中处理表单有很多种方法,这里说到第一种方式:Ajax+Jquery 先看下表单: <form class="row form-body form-horizontal m-t&q ...
- form表单里如果只存在一个文本框,enter键提交
在这里说一说浏览器里form表单的默认行为 我们都知道浏览器是存在很多默认行为的,可能是出于常用行为考虑又或者是历史原因.但有时候我们不需要这些默认行为.以下: 1).当form表单里只存在一个inp ...
- laravel中form表单,ajax传值没反应
laravel中form表单,ajax传值没反应时,可能是令牌有问题. form中添加: {{csrf_token()}} ajax中添加: data: {'page': page, '_token' ...
随机推荐
- Step by step Process of creating APD
Step by step Process of creating APD: Business Scenario: Here we are going to create an APD on top o ...
- ORACLE 10g下载地址
ORACLE 10g下载地址 oracle 下载还需要用户名我自己注册了个方便大家使用下载 密码是这个 一般不会动了 大家也不用帮我找回密码了 每次都改 也很麻烦的如果有需要可以帮我浏览下 右侧的需要 ...
- C#按需序列化对象为Json字符串
只贴代码,不解释了.新的代理类型确实很给力! public static class JsonHelper { public static string ToJsonString<T>(I ...
- 云计算相关的一些概念Baas、Saas、Iaas、Paas
BaaS(后端即服务:Backend as a Service)公司为移动应用开发者提供整合云后端的边界服务. SaaS(软件即服务:Software as a Service)提供了完整的可直接使用 ...
- data-role参数表:
data-role参数表: page 页面容器,其内部的mobile元素将会继承这个容器上所设置的属性 header 页面标题容器,这个容器内部可以包含文字.返回按钮.功能按钮等 ...
- Hadoop 2.4.1 设置问题小结【原创】
先丢点问题小结到这里,免得忘记,有空再弄个详细教程玩,网上的教程要不就是旧版的,要不就是没说到点子上,随便搞搞也能碰上结果是对的时候,但是知其然而不知其所以然,没意思啊.解决问题的方法有很多种,总得找 ...
- A little problem for pt-pmp
https://bugs.launchpad.net/percona-toolkit/+bug/1320168 We use the pt-pmp (a variety for pmp !http:/ ...
- Promising Linking
Future/Promise 执行逻辑 scala Future 有几个要点,第一个是 tryAwait 需要借助 CowndownLatch 实现,第二个是可以在 Promise 挂载回调函数 首先 ...
- JavaScript封装Ajax(类JQuery中$.ajax()方法)
ajax.js (function(exports, document, undefined){ "use strict"; function Ajax(){ if(!(this ...
- android EditText inputType说明
在开发的过程中,通常会用到EditText,如何让虚拟键盘来适应输入框中内容的类型,通常我们都会在xml文件中加入android:inputType="". android:inp ...