ActionInvoker的作用是:根据请求数据(HttpPost,HttpGet等)和action名称,来激发响应的action,再由action渲染视图。本文通过自定义ActionInvoker,根据请求类型直接渲染视图。

控制器中有这样的一个Action:

public ActionResult Demo()
        {
            return View();
        }

当请求该action的时候,我们希望:如果是Get请求,我们直接渲染视图DemoGet.cshtml;如果是Post请求,我们直接渲染视图DemoPost.cshtml。于是,我们需要扩展默认的ControllerActionInvoker类。

using System.Web.Mvc;
 
namespace MvcApplication1.Extension
{
    public class MyActionInvoker : ControllerActionInvoker
    {
        public override bool InvokeAction(ControllerContext controllerContext, string actionName)
        {
            if (controllerContext.HttpContext.Request.RequestType == "GET" && actionName == "Demo")
            {
                ViewResult viewResult = new ViewResult();
                viewResult.View = viewResult.ViewEngineCollection.FindView(controllerContext, "DemoGet", null).View;
                InvokeActionResult(controllerContext, viewResult);
                return true;
            }
            else if (controllerContext.HttpContext.Request.RequestType == "POST" && actionName == "Demo")
            {
                ViewResult viewResult = new ViewResult();
                viewResult.View = viewResult.ViewEngineCollection.FindView(controllerContext, "DemoPost", null).View;
                InvokeActionResult(controllerContext, viewResult);
                return true;
            }
            else
            {
                return base.InvokeAction(controllerContext, actionName);
            }
            
        }
    }
}
 

在控制器的构造函数中启用自定义ActionInvoker。

        public HomeController()
        {
            this.ActionInvoker = new MyActionInvoker();
        }

DemoGet.cshtml视图为:

@{
    ViewBag.Title = "DemoGet";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
 
<h2>DemoGet</h2>
 
@using (Html.BeginForm("Demo", "Home", FormMethod.Post, new {id = "form1"}))
{
    <input type="text" name="name" id="name"/>
    <input type="submit" value="提交" name="submit" id="submit"/>
}
 
@section scripts
{
    <script type="text/javascript">
        $(function() {
            $('#submit').click(function() {
                var name = $('#name').val();
                var url = $('#form1').attr('action');
                url = url + '?name=' + name;
                $('#form1').attr('action', url);
            });
        });
    </script>
}

DemoPost.cshtml视图为:

@{
    ViewBag.Title = "DemoPost";
    Layout = "~/Views/Shared/_Layout.cshtml";
}
 
<h2>DemoPost</h2>
@{ string name = string.Empty;}
@if (HttpContext.Current.Request.QueryString["name"] != null)
{
    name = HttpContext.Current.Request.QueryString["name"].ToString();
}
 
@name
 

当在浏览器中输入:/Home/Demo的时候,是Get请求,返回DemoGet.cshtml视图:

当点击提交按钮,对/Home/Demo的是Post请求,返回DemoPost.cshtml视图:

小结:

对于某个控制器方法,可以根据请求数据(有可能是GET,POST,也有可能是其它请求数据,因为可以从HttpContext.Current.Request中拿到很多请求数据)的不同,直接渲染出视图。不一定通过如下方式:

[HttpGet]

public ActionResult SomeAction()

[HttpPost]

public ActionResult SomeAction()

参考资料:

Controller Factory and Action Invoker Part 2

MVC扩展ActionInvoker,自定义ActionInvoker,根据请求数据返回不同视图的更多相关文章

  1. 09.VUE学习之watch监听属性变化实现类百度搜索栏功能ajax异步请求数据,返回字符串

    cmd下安装axios npm install axios 安装好后,会多出node_modules文件夹 思路: 监听data里的word改变时,发送ajax异步请求数据, 把返回的数据赋值给dat ...

  2. django view 视图控制之数据返回的视图函数

    八.视图 view 概述:views.py定义的python函数,它接受Web请求并且返回Web响应. 有几个页面就有几个视图view user出入url地址,发送request--->urls ...

  3. 09.1.VUE学习之watch监听属性变化实现类百度搜索栏功能ajax异步请求数据,返回数组

    09.1html里 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> < ...

  4. spring mvc 通过拦截器记录请求数据和响应数据

    spring mvc 能过拦截器记录请求数据记录有很多种方式,主要有以下三种: 1:过滤器 2:HandlerInterceptor拦截器 3:Aspect接口控制器 但是就我个人所知要记录返回的数据 ...

  5. 关于Http请求后返回json乱码的问题

    其实很多时候我们在做http请求数据返回的时候经常会莫名发现会出现乱码,大部分时候我们都觉得是编码不对造成的. 一般情况下正常我们默认都是作个很简单的操作,直接使用UTF-8编码基本问题就搞定了 Ht ...

  6. SpringMVC总结三:请求Controller返回视图类型以及请求方式、参数介绍

    视图解析,请求Controller返回的视图类型: @Controller @RequestMapping("/test") public class TestController ...

  7. Struts2 请求数据的自动封装 及 自定义转换器类

    请求数据自动封装: 实现原理:使用了参数拦截器.struts-default.xml中 <interceptor name="params" class="com. ...

  8. vue使用element Transfer 穿梭框实现ajax请求数据和自定义查询

    vue使用element Transfer 穿梭框实现ajax请求数据和自定义查询 基于element Transfer http://element-cn.eleme.io/#/zh-CN/comp ...

  9. 【Spring学习笔记-MVC-5】利用spring MVC框架,实现ajax异步请求以及json数据的返回

    作者:ssslinppp      时间:2015年5月26日 15:32:51 1. 摘要 本文讲解如何利用spring MVC框架,实现ajax异步请求以及json数据的返回. Spring MV ...

随机推荐

  1. The Art Of Computer Programming: 1.1

    The Art Of Computer Programming: 1.1 */--> div.org-src-container { font-size: 85%; font-family: m ...

  2. Linux命令之远程登录与执行远程主机命令

    实现远程登录的命令 ssh.telnet.rlogin (1)ssh命令 ssh命令是openssh套件中的客户端连接工具,可以给予ssh加密协议实现安全的远程登录服务器.ssh命令用于远程登录上Li ...

  3. 20165203 实验一 Java开发环境的熟悉

    实验内容及步骤 实验一 Java开发环境的熟悉-1 建立有自己学号的实验目录. 通过vim Hello.java编辑代码. 编译.运行Hello.java代码. 实验一 Java开发环境的熟悉-2 新 ...

  4. echart 打开新世界的大门

    实时折线图 option = { backgroundColor:'#2B2B2B', tooltip: { trigger: 'axis' }, legend: { data:['频率'], tex ...

  5. USACO 4.3 Buy Low, Buy Lower

    Buy Low, Buy Lower The advice to "buy low" is half the formula to success in the stock mar ...

  6. gluster学习(一)

    2)Bricks • Brick是一个节点和一个导出目录的集合,e.g. node1:/brick1 • Brick是底层的RAID或磁盘经XFS或ext4文件系统格式化而来,所以继承了文件系统的限制 ...

  7. Code First 数据库迁移

    当 Entity Framework Code First 的数据模型发生改变时,默认会引发一个System.InvalidOperationException 的异常.解决方法是使用DropCrea ...

  8. 使用chrales抓包IOS的https(pc+手机)

    1.安装SSL证书到手机 点击 Help -> SSL Proxying -> Install Charles Root Certificate on a Mobile Device 2. ...

  9. Ubuntu16.04 下的网易云出现网络异常、无法播放,界面无响应问题的统一解决

    能够在Linux系统下体验到原生界面的网易云音乐是件不错的事情,但是它总是经常性的出现网络异常,界面无响应的问题 为了听歌的体验,进行深入探究: 首先通过终端启用网易云音乐:sudo netease- ...

  10. uboot的使用

    嵌入式软件的层次: bootloader +boot_parameter+kernel+ boot filesystem <uboot的编译> 1)将uboot压缩文件拷贝到 linux系 ...