专栏首页DOTNETASP.NET MVC编程——控制器

ASP.NET MVC编程——控制器

每一个请求都会经过控制器处理,控制器中的每个方法被称为控制器操作,它处理具体的请求。

1操作输入参数

控制器的操作的输入参数可以是内置类型也可以是自定义类型。

2操作返回结果

结果类型

调用方法

备注

ContentResult

Content

文本类型

FileContentResult/FileStreamResult/FilePathResult

File

文件类型

HttpStatusCodeResult(HttpNotFoundResult,HttpUnauthorizedResult)

HttpNotFound

包含404,401状态码

JavaScriptResult

JavaScript

JavaScript代码

JsonResult

Json

Json字符串

PartialViewResult

PartialView

部分视图

RedirectResult

Redirect/RedirectPermanent

跳转到给定URL

RedirectToRouteResult

RedirectToAction/RedirectToRoute

重定向到指定的路由

ViewResult

View

指定视图

EmptyResult

不返回任何内容

上述返回值类型均继承自ActionResult,除了上述类型外,控制器可以返回任意的类型!

3 HTTP动词特性

特性有HttpGet、HttpPost、HttpDelete、HttpPut、HttpHead、HttpOptions、HttpPatch,当没有限定任何动词时,不论何种请求,get,post,put等等,被请求的操作都会被调用。

4 操作过滤器

过滤器接口有

授权过滤器:public interface IAuthorizationFilter

动作过滤器:public interface IActionFilter

身份验证过滤器:public interface IAuthenticationFilter

异常过滤器:public interface IExceptionFilter

结果过滤器:public interface IResultFilter

1)AuthorizeAttribute

public class AuthorizeAttribute : FilterAttribute, IAuthorizationFilter

AuthorizeAttribute的两个常用属性

Roles:获取或设置有权访问控制器或操作方法的用户角色。

Users:获取或设置有权访问控制器或操作方法的用户。

可以在Web.config的<system.web>配置未通过验证跳转的页面:

<authentication mode="Forms">

   <forms loginUrl="~/Account/Login"></forms>

</authentication>

配合其使用的属性

AllowAnonymous

public sealed class AllowAnonymousAttribute : Attribute

允许跳过AuthorizeAttribute的验证执行控制器操作。

2)ChildActionOnlyAttribute

public sealed class ChildActionOnlyAttribute : FilterAttribute, IAuthorizationFilter

指示操作方法只能作为子操作进行调用

例:

控制器

public class HomeController : Controller
{
        [ChildActionOnly]
        public ActionResult TestPy()
        {
            return PartialView();
        }
}

分部视图TestPy.cshtml:

<div>
   <h1>这是部分视图</h1>
</div>

调用页Index.cshtml:

<div class="row">
    <a href="@Url.Action("Home", "TestPy")">点击调用分部视图</a>
</div>

执行报错:404!

将调用页代码修改如下:

<div class="row">
    @Html.Action("TestPy")
</div>

运行可以正常显示部分视图内容

3)RequireHttpsAttribute

public class RequireHttpsAttribute : FilterAttribute, IAuthorizationFilter

强制通过 HTTPS 重新发送不安全的 HTTP 请求

4)ValidateInputAttribute

public class ValidateInputAttribute : FilterAttribute, IAuthorizationFilter

验证通过窗体传进来的信息

5)ValidateAntiForgeryTokenAttribute

public sealed class ValidateAntiForgeryTokenAttribute : FilterAttribute, IAuthorizationFilter

阻止伪造请求

6)AsyncTimeoutAttribute

public class AsyncTimeoutAttribute : ActionFilterAttribute

设置异步操作超时时间

7)NoAsyncTimeoutAttribute

public sealed class NoAsyncTimeoutAttribute : AsyncTimeoutAttribute

设置异步操作永不超时

8)OutputCacheAttribute

public class OutputCacheAttribute : ActionFilterAttribute, IExceptionFilter

将缓存其输出的操作方法

9)HandleErrorAttribute

public class HandleErrorAttribute : FilterAttribute, IExceptionFilter

处理由操作方法引发的异常

10)ActionNameAttribute

[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]

public sealed class ActionNameAttribute : ActionNameSelectorAttribute

可以使用此特性改变操作的名称,使用新名称作为路由参数,方可路由到该操作

例:

[ActionName("AboutName")]
public ActionResult About()
{
    ......
}

11)NonActionAttribute

[AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)]

public sealed class NonActionAttribute : ActionMethodSelectorAttribute

使用此特性修饰控制器操作,不会路由到此控制器方法

5向视图传递数据

与其说传递数据,倒不如说视图如何获得控制器处理过的数据。视图通过两种方式可以拿到数据:

1)通过控制器操作返回的结果(控制器返回结果是数据和视图的结合。

2)将结果赋给控制器属性并在View中使用这些属性。

public abstract class ControllerBase : IController

类中有三个属性ViewData、ViewBag、TempData,使用着三个属性向视图传递数据。

ViewData

它是字典类型

public ViewDataDictionary ViewData { get; set; }

public class ViewDataDictionary : IDictionary<string, object>, ICollection<KeyValuePair<string, object>>, IEnumerable<KeyValuePair<string, object>>, IEnumerable

例:

第一种方式,弱类型

控制器

public ActionResult TestViewData()
{
            ViewData["Field"] = "VD";
            return View("Contact");
}

视图Contact.cshtml

@ViewData["Field"]

在Index.cshtml视图中调用

 @Html.Action("TestViewData")

第二种方式,弱型别,使用ViewData.Model

这种方式无法使用VS编译器的智能提示功能

控制器

public ActionResult TestViewData()
{
            ViewData.Model = new ModelF { Field="VD"};
            return View("Contact");
}

视图Contact.cshtml

@Model.Field

在Index.cshtml视图中调用

@Html.Action("TestViewData")

第三种方式,强型别,使用ViewData.Model

控制器与第二种方式基本相同,不同点就是视图Contact.cshtml

@model MVCPointApp.Models.ModelF
@Model.Field

ViewBag

它是动态类型,对ViewData的包装

public dynamic ViewBag { get; }

例:

控制器操作中ViewBag.Field

使用@ViewBag.Message

TempData

它也是字典类型

public TempDataDictionary TempData { get; set; }

public class TempDataDictionary : IDictionary<string, object>, ICollection<KeyValuePair<string, object>>, IEnumerable<KeyValuePair<string, object>>, IEnumerable

6 异步控制器

原理:

ASP.NET从线程池获得线程处理异步请求,异步调用完后,该线程回到线程池以便可以处理其他请求,同时通知ASP.NET重新抓取一个线程(不一定是处理异步请求的线程)来完成具体的异步操作(输出数据等)。

使用异步控制器的目的:

异步控制器操作中也要等待任务直至处理完,所以处理速度不比同步方法快,其主要作用是高效地利用服务器资源。

使用异步控制器的情形:

可能引发瓶颈的长操作,网络或I\O密集型操作,可取消长操作的情形。

构建异步控制器:

控制器继承AsyncController,控制器操作返回Task<ActionResult>,并用async 修饰。

public class AnysController : AsyncController
{
        // GET: Anys
        public async Task<ActionResult> Index()
        {
            //睡眠,模拟长任务
            Thread.Sleep(5000000);
            return View("Testpy");
        }
 }

7 扩展控制器

基类控制器

定义一个基类控制器,以便处理异常或无法找到请求对应的操作。

注意如果控制器使用HttpPost特性修饰,而客户端发起的是get请求,也会认为是无法找到操作。

例:

    public class BaseController : Controller
    {
        protected override void OnException(ExceptionContext filterContext)
        {
            //错误日志记录
        }

        protected override void HandleUnknownAction(string actionName)
        {
            //处理能找到此控制器,但找不到请求对应的操作
        }
    }

扩展授权过滤器(AuthorizeAttribute)

具体示例见:验证、授权与安全

动作过滤器(ActionFilterAttribute

ActionFilterAttribute是一个抽象类,有四个方法:

操作执行后被框架自动调用的方法:OnActionExecuted

操作执行前被框架自动调用的方法:OnActionExecuting

返回结果后被框架自动调用的方法:OnResultExecuted

返回结果前被框架自动调用的方法:OnResultExecuting

参考:

1.Jess Chadwick/Todd Snyder/Hrusikesh Panda,徐雷/徐扬

译。ASP.NET MVC4 Web编程

2.Jon Galloway/Phil Haack/Brad Wilson/K. Scott Allen,孙远帅/邹权译  ASP.NET MVC4 高级编程(第四版)

3.黄保翕,ASP.NET MVC4开发指南

4.蒋金楠,ASP.NET MVC4框架揭秘

5.https://www.asp.net/mvc

-----------------------------------------------------------------------------------------

转载与引用请注明出处。

时间仓促,水平有限,如有不当之处,欢迎指正。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ASP.NET MVC编程——错误处理与日记

    ASP.NET MVC的错误处理应考虑到这几个方面:模型绑定期间发生的错误,未能路由到指定操作,针对控制器的错误处理。使用配置文件可以帮助我们处理异常,但是不够...

    甜橙很酸
  • 设计原则

    一、面向对象应用程序开发原则(SOLID) 1单一职责原则(SRP) 定义: 一个类应该只有一个发生变化的原因。这条原则曾被称为内聚性,即一个模块的组成元素之间...

    甜橙很酸
  • Entity Framework——建模建库

    1数据库初始化策略选择 三种初始化策略: 1)CreateDatabaseIfNotExists:默认的策略。如果数据库不存在,那么就创建数据库。但是如果数据库...

    甜橙很酸
  • 脱坑神器,让你一步了解ODL控制器集群

    一、控制器集群基本知识 1.1 Consensus一致性 Consensus一致性是指多个服务器在状态达成一致,但是在一个分布式系统中,因为各种意外可能,有的...

    SDNLAB
  • ASP.NET MVC编程——错误处理与日记

    ASP.NET MVC的错误处理应考虑到这几个方面:模型绑定期间发生的错误,未能路由到指定操作,针对控制器的错误处理。使用配置文件可以帮助我们处理异常,但是不够...

    甜橙很酸
  • C++经典算法题-快速排序法(一)

    快速排序法(quick sort)是目前所公认最快的排序方法之一(视解题的对象而定),虽然快速排序法在最差状况下可以达O(n2),但是在多数的情况下,快速排序法...

    cwl_java
  • OpenDaylight与Mininet应用实战之OpenFlow协议分析

    1、实验目的 在实验平台上熟悉SDN原理操作,通过wireshark抓包工具可以直接看到控制器与OVS交换机的通信过程、分析OpenFlow(以下简写为OF)协...

    SDNLAB
  • LeetCode 316. Remove Duplicate Letters(贪心)

    题解:贪心,咱们从结果字符串的左边开始,左边第一个字符在原字符串中的右边一定有n-1个不同的字符,这里n就是结果字符串的长度。 所以我们每次遍历数组,找到右边...

    ShenduCC
  • 认识ASP.NET MVC的5种AuthorizationFilter

    在总体介绍了筛选器及其提供机制(《深入探讨ASP.NET MVC的筛选器》)之后,我们按照执行的先后顺序对四种不同的筛选器进行单独介绍,首先来介绍最先执行的Au...

    蒋金楠
  • 荣登Nature,时隔15年NumPy论文终发表!

    NumPy是一个强大、紧凑和表达力强的语法来访问、操作和计算向量、矩阵和高维数组的科学计算库。

    新智元

扫码关注云+社区

领取腾讯云代金券