ASP.NET MVC限制同一個IP地址單位時間間隔內(nèi)的請求次數(shù)
有時候,當(dāng)用戶請求一個Controller下的Action,我們希望,在單位時間間隔內(nèi),比如每秒,每分鐘,每小時,每天,每星期,限制同一個IP地址對某個Action的請求次數(shù)。如何做呢?
stefanprodan的MvcThrottle能很好地解決這個問題,以及其它類型的IP限制問題。在這里:https://github.com/stefanprodan/MvcThrottle
把項(xiàng)目從GitHub下載下來,在本地打開。
找到MvcThrottle類庫,打開ThrottlingFilter這個類,在該類的OnActionExecuting方法中修改如下:
//check if limit is reachedif (rateLimit > 0 && throttleCounter.TotalRequests > rateLimit){ //log blocked request if (Logger != null) Logger.Log(ComputeLogEntry(requestId, identity, throttleCounter, rateLimitPeriod.ToString(), rateLimit, filterContext.HttpContext.Request)); //break execution and return 409 var message = string.IsNullOrEmpty(QuotaExceededMessage) ?"HTTP request quota exceeded! maximum admitted {0} per {1}" : QuotaExceededMessage; //add status code and retry after x seconds to response filterContext.HttpContext.Response.StatusCode = (int)QuotaExceededResponseCode; filterContext.HttpContext.Response.Headers.Set("Retry-After", RetryAfterFrom(throttleCounter.Timestamp, rateLimitPeriod)); filterContext.Result = QuotaExceededResult(filterContext.RequestContext,string.Format(message, rateLimit, rateLimitPeriod),QuotaExceededResponseCode,requestId); return;}
把以上替換成
//check if limit is reachedif (rateLimit > 0 && throttleCounter.TotalRequests > rateLimit){ filterContext.HttpContext.Response.Redirect("/Error.html"); return;}
讓其在超過次數(shù)時,跳轉(zhuǎn)到項(xiàng)目根目錄下的Error.html文件。
生成該類庫,類庫MvcThrottle.dll生成在類庫的bin/Debug文件夾下。
在ASP.NET MVC 4 下創(chuàng)建一個項(xiàng)目。
在項(xiàng)目根目錄下創(chuàng)建一個Library文件夾,把剛才的MvcThrottle.dll拷貝其中。
引用Library文件夾下的MvcThrottle.dll組件。
在App_Start文件夾中,修改FilterConfig類如下:
public class FilterConfig {public static void RegisterGlobalFilters(GlobalFilterCollection filters){ var throttleFilter = new ThrottlingFilter {Policy = new ThrottlePolicy(perSecond: 1, perMinute: 10, perHour: 60 * 10, perDay: 600 * 10){ IpThrottling = true},Repository = new CacheRepository() }; filters.Add(throttleFilter);} }
創(chuàng)建HomeController,編寫如下:
public class HomeController : Controller {public ActionResult Index(){ return View();}[EnableThrottling(PerSecond = 2, PerMinute = 5, PerHour = 30, PerDay = 300)]public ActionResult Other(){ return View();}[HttpPost][EnableThrottling(PerSecond = 2, PerMinute = 5, PerHour = 30, PerDay = 300)]public ActionResult GetSth(){ return Json(new {msg=true});} }
生成解決方案。
報錯了!What Happened?
原來MvcThrottle是ASP.NET MVC 5下開發(fā)的。
有辦法。重新打開MvcThrottle項(xiàng)目的類庫,在引用中刪除原來的System.Web.Mvc,重新引用本地ASP.NET MVC4版本,重新引用本地的System.Web.Mvc。
重新生成類庫,重新拷貝到Library文件夾下,成功生成解決方案。
在Home/Index.cshtml視圖中:
@{ ViewBag.Title = "Index"; Layout = "~/Views/Shared/_Layout.cshtml";}<h2>Index</h2><input type="button" id="btn" value="請求"/>@section scripts{ <script type="text/javascript">$(function() { $("#btn").on("click", function() {$.post("@Url.Action("GetSth")",function(data) { if (data.msg) {alert("請求成功一次"); } else {alert("請求次數(shù)過多"); }}); });}); </script>}
當(dāng)在單位時間間隔內(nèi)超過規(guī)定次數(shù),就彈出"請求次數(shù)過多"提示框。
在Home/Other.cshtml視圖中:
@{ ViewBag.Title = "Other"; Layout = "~/Views/Shared/_Layout.cshtml";}<h2>Other</h2>
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,謝謝大家對的支持。如果你想了解更多相關(guān)內(nèi)容請查看下面相關(guān)鏈接
相關(guān)文章:
1. ASP.NET MVC通過勾選checkbox更改select的內(nèi)容2. ASP.NET MVC使用JSAjaxFileUploader插件實(shí)現(xiàn)單文件上傳3. ASP.NET MVC視圖頁使用jQuery傳遞異步數(shù)據(jù)的幾種方式詳解4. ASP.NET MVC實(shí)現(xiàn)區(qū)域或城市選擇5. ASP.NET MVC實(shí)現(xiàn)單個圖片上傳、限制圖片格式與大小并在服務(wù)端裁剪圖片6. ASP.NET MVC解決上傳圖片臟數(shù)據(jù)的方法7. ASP.NET MVC使用異步Action的方法8. ASP.NET MVC增加一條記錄同時添加N條集合屬性所對應(yīng)的個體9. log4net在Asp.net MVC4中的使用過程10. ASP.NET MVC實(shí)現(xiàn)橫向展示購物車
