今天有位同事,提出了這樣一個(gè)問題,他想限制所有MVC接收到的HTTP請求必須是POST方式。
接下來在下面的內(nèi)容中,將我想到的方式分享給大家,如果大家有其它的方式,請留言。
一、HttpPostAttribute特性
大家首先想到時(shí)的,MVC提供了HttpPostAttribute特性,是用于限制HTTP請求必須POST方式來提交。
public class HomeController : Controller { [HttpPost] public ActionResult Index() { return View(); } }
這個(gè)特性只能在Action方法上面做標(biāo)記,需要我們在每一個(gè)Action方法上面做標(biāo)記,做一個(gè)Coder,這種方式,我們肯定接收不了。
// // 摘要: // 表示一個(gè)特性,該特性用于限制操作方法,以便該方法僅處理 HTTP POST 請求。 [AttributeUsage(AttributeTargets.Method, AllowMultiple = false, Inherited = true)] public sealed class HttpPostAttribute : ActionMethodSelectorAttribute { }
二、使用HttpModule
Asp.Net管線中,可以通過 HttpModule 對 HttpApplication 對象中的事件注冊自己的事件處理程序,來控制所有的HTTP請求。
public class HttpMethodModule : IHttpModule { public void Init(HttpApplication context) { context.PostMapRequestHandler += Context_PostMapRequestHandler; } private void Context_PostMapRequestHandler(object sender, EventArgs e) { HttpApplication httpApplication = (HttpApplication) sender; HttpContext httpContext = httpApplication.Context; //判斷當(dāng)前是否使用的是 MVC 框架來處理請求,其它的請示不做控制。 MvcHandler mvcHandler = httpContext.Handler as MvcHandler; if (mvcHandler != null && httpContext.IsPostMethod() == false) { throw new HttpException(404, "訪問的資源不存在。"); } } public void Dispose() { } }
在Web.config增加相關(guān)的配置。
<?xml version="1.0" encoding="utf-8"?><configuration> <system.webServer> <modules> <add name="HttpMethod" type="HttpPostWebApp.Web.HttpMethodModule, HttpPostWebApp"/> </modules> </system.webServer></configuration>
經(jīng)過測試,是可以達(dá)到我們的要求(關(guān)于測試結(jié)果不在做演示)。
三、MVC過濾器
在MVC中,可以通過全局的過濾器來控制請求。
public class HttpPostFilter : IAuthorizationFilter { public void OnAuthorization(AuthorizationContext filterContext) { if (filterContext.HttpContext.IsPostMethod() == false) { //如果不是POST請求,則返回404。 filterContext.Result = new HttpNotFoundResult(); } } }
在程序啟動時(shí),注冊為全局過濾器。
public class FilterConfig { public static void RegisterGlobalFilters(GlobalFilterCollection filters) { filters.Add(new HttpPostFilter()); } }
新聞熱點(diǎn)
疑難解答
圖片精選