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;
        }
    }
}

登录页面的效果如图

登录成功页面

登录失败页面

注意:登录失败时,也可以重定向在原先的登录页面

时间: 2024-10-10 00:12:51

asp.net.mvc 中form表单提交控制器的2种方法和控制器接收页面提交数据的4种方法的相关文章

MVC中Form表单的提交

Form表单是数据提交的一种,在MVC中Form表单提交到服务器中地址,接受Form表单的方式有一下几种: 1.采用实体Model类型提交,Form表单中的Input标签name要和Model对应的属性保持一致,接受Form表单的服务器端就可以直接以实体的方式存储,使用方式如下: Form表单: <form action="/Employee/SaveEmployee" method="post"> <table> <tr> &l

form表单中控件较多,加载完成后切换页面都很慢的解决方法

form表单中控件较多,加载完成后点击都很慢,为什么?我一页面中form表单里面上百个控件(如input.select.radio.checkbox等),还有一些js脚本,加载速度还可以,都能全部显示完毕,但是点击一些事件(如切换tab.关闭模拟框,点击radio等)都非常慢,不知道为什么? 当我采用inprivate模式浏览时,以上动作都很快,但老用inprivate也麻烦,有何办法解决. 按理说form都在客户端显示完全了,其他操作都是客户端的操作阿应该不慢才对阿/. ------解决思路-

ASP.NET MVC 与Form表单交互

一 一,Form包含文件类(单选文件) <form id="ImgForm" method="POST" enctype="multipart/form-data" name="ImgForm" action="/From/SubmitForm"> <input type="file" name="fileData" > <br />

mvc中form表单提交的几种形式

第一种方式:submit 按钮 提交 <form action="MyDemand" method="post"> <span>关键字:</span> <input name="keywords" type="text" value="@keywords" /> <input type="submit" value="搜索&

MVC中处理表单提交的方式(Ajax+Jquery)

MVC中处理表单有很多种方法,这里说到第一种方式:Ajax+Jquery 先看下表单: <form class="row form-body form-horizontal m-t"> <div class="col-md-6"> <div class="form-group"> <label class="col-sm-3 control-label">订单编号:</la

extjs中form表单提交成功、失败的响应信息

类Ext.form.Action.Submit 处理表单Form数据和返回的response对象的类. 该类的实例仅在表单Form{@link Ext.form.BasicForm#submit 提交}的时候创建. 返回的数据包必须包含一个 boolean 类型的success属性,还有可选地,一个含有无效字段的错误信息的属性 A response packet may contain: ·        success property : Boolean - required. ·     

form表单里如果只存在一个文本框,enter键提交

在这里说一说浏览器里form表单的默认行为 我们都知道浏览器是存在很多默认行为的,可能是出于常用行为考虑又或者是历史原因.但有时候我们不需要这些默认行为.以下: 1).当form表单里只存在一个input输入框时,回车会提交表单操作.  解决方法可以在form里面再加入一个隐藏的input输入框,或者把input从form里面放出来. 2).当form表单里有一个type=”submit”的按钮,回车会自动提交. 3).当form表单里的button按钮没有加type类型时,在ie下默认是but

asp.net MVC中form提交和控制器接受form提交过来的数据

MVC中form提交和在控制器中怎样接受 1.cshtml页面form提交2.控制器处理表单提交数据4种方式方法1:使用传统的Request请求取值[HttpPost]public ActionResult AddNews(){    string a=Request["text1"];    string b=Request["text2"];}方法2:Action参数名与表单元素name值一一对应[HttpPost]public ActionResult Add

angularjs中form表单提交验证

angular.module("MyApp",["ngMessages"]): <form name="formMyName" ng-submit="$ctrl.changePassword(formMyName)" ng-cloak novalidate> <--输入新密码--> <md-input-container md-no-float> <input name="n