前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ASP.NET MVC编程——控制器

ASP.NET MVC编程——控制器

作者头像
甜橙很酸
发布2018-03-30 10:14:21
2.1K0
发布2018-03-30 10:14:21
举报
文章被收录于专栏:DOTNETDOTNET

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

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

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

例:

控制器

代码语言:javascript
复制
public class HomeController : Controller
{
        [ChildActionOnly]
        public ActionResult TestPy()
        {
            return PartialView();
        }
}

分部视图TestPy.cshtml:

代码语言:javascript
复制
<div>
   <h1>这是部分视图</h1>
</div>

调用页Index.cshtml:

代码语言:javascript
复制
<div class="row">
    <a href="@Url.Action("Home", "TestPy")">点击调用分部视图</a>
</div>

执行报错:404!

将调用页代码修改如下:

代码语言:javascript
复制
<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

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

例:

代码语言:javascript
复制
[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

例:

第一种方式,弱类型

控制器

代码语言:javascript
复制
public ActionResult TestViewData()
{
            ViewData["Field"] = "VD";
            return View("Contact");
}

视图Contact.cshtml

代码语言:javascript
复制
@ViewData["Field"]

在Index.cshtml视图中调用

代码语言:javascript
复制
 @Html.Action("TestViewData")

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

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

控制器

代码语言:javascript
复制
public ActionResult TestViewData()
{
            ViewData.Model = new ModelF { Field="VD"};
            return View("Contact");
}

视图Contact.cshtml

代码语言:javascript
复制
@Model.Field

在Index.cshtml视图中调用

代码语言:javascript
复制
@Html.Action("TestViewData")

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

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

代码语言:javascript
复制
@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 修饰。

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

7 扩展控制器

基类控制器

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

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

例:

代码语言:javascript
复制
    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

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

转载与引用请注明出处。

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

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018-03-23 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
多因子身份认证
多因子身份认证(Multi-factor Authentication Service,MFAS)的目的是建立一个多层次的防御体系,通过结合两种或三种认证因子(基于记忆的/基于持有物的/基于生物特征的认证因子)验证访问者的身份,使系统或资源更加安全。攻击者即使破解单一因子(如口令、人脸),应用的安全依然可以得到保障。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档