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. Windows开机自动启动pageant,方便使用ssh链接到GitHub

    按win +r,输入 shell:startup "C:\Program Files\TortoiseGit\bin\pageant.exe" "d:\GitHubPri ...

  2. PHP随机浮点数

    function randomFloat($min = 0, $max = 1) { $rand = mt_rand(); $lmax = mt_getrandmax(); return $min + ...

  3. java.lang.NoClassDefFoundError: ognl/PropertyAccessor

    本篇对 Web 开发中,项目部署后.开启 Tomcat 服务器 Console 控制台报错 java.lang.NoClassDefFoundError: ognl/PropertyAccessor ...

  4. Bootstrap--响应式导航条布局

    <!DOCTYPE html> <html> <head> <meta name="viewport" content="wid ...

  5. 8-4 Fabled Rooks uva11134

    题意:你的任务是在n*n的棋盘上放 n 小于5000 个车 使得任意两个车不互相攻击 且第i个车在一个给定的矩形ri之内  给出该矩形左上角坐标和右下角坐标四个点  必须满足放车的位置在矩形内  边上 ...

  6. poj1970 The Game(DFS)

    题目链接 http://poj.org/problem?id=1970 思路 题目的意思是判断五子棋棋局是否有胜者,有的话输出胜者的棋子类型,并且输出五个棋子中最左上的棋子坐标:没有胜者输出0. 这道 ...

  7. RTSP 资料

    分享两个不错的播客. http://blog.csdn.net/u010425035/article/details/10410851 http://blog.csdn.net/xiaoyafang1 ...

  8. 洛谷P4645 [COCI2006-2007 Contest#7] BICIKLI [Tarjan,拓扑排序]

    题目传送门 BICIKLI 题意翻译 给定一个有向图,n个点,m条边.请问,1号点到2号点有多少条路径?如果有无限多条,输出inf,如果有限,输出答案模10^9的余数. 两点之间可能有重边,需要看成是 ...

  9. 洛谷——P2083 找人

    P2083 找人 题目背景 无 题目描述 小明要到他的同学家玩,可他只知道他住在某一单元,却不知住在哪个房间.那个单元有N层(1,2……N),每层有M(1,2……M)个房间. 小明会从第一层的某个房间 ...

  10. Android消息总线的演进之路:用LiveDataBus替代RxBus、EventBus

    背景 对于Android系统来说,消息传递是最基本的组件,每一个App内的不同页面,不同组件都在进行消息传递.消息传递既可以用于Android四大组件之间的通信,也可用于异步线程和主线程之间的通信.对 ...