为了防止爬虫以及恶意请求,我们适当的为API增加一个请求限制 WebApiThrottle限流框架
WebApiThrottle支持自定义配置各种限流策略。可以根据不同场景配置多个不同的限制,比如授权某个IP每秒、每分钟、每小时、每天、每周的最大调用次数。 这些限制策略可以配置在所有请求上,也可以单独给每个API接口去配置。
--十色鹿
本文不再过多讲解理论,你们可以看看这两位大佬文章,都解释很详细了(链接在底部)
API 还是使用上次的 如果没新建,请看 -> https://www.cnblogs.com/whatarey/p/11438243.html
第一步 NuGet WebApiThrottle
第二步 WebApiConfig.cs 配置
1 #region web api 接口请求限制~~1 2 ///// web api 接口请求限制~~ 3 //config.Filters.Add(new ThrottlingHandler() 4 //{ 5 // Policy = new ThrottlePolicy() 6 // { 7 8 // //ip配置区域 9 // IpThrottling = true, 10 // ClientThrottling = true, 11 12 // //端点限制策略配置会从EnableThrottling特性中获取。 13 // EndpointThrottling = true 14 15 // } 16 //}); 17 #endregion 18 19 #region Web Api 接口请求限制 2 20 21 //WebApiConfig 增加 22 config.MessageHandlers.Add(new ThrottlingHandler() 23 { 24 Policy = new ThrottlePolicy( 25 perSecond: 5 //可选参数 每秒限制次数 26 , perMinute: 20 //可选参数 每分钟限制次数 27 , perHour: 200 //可选参数 每小时限制次数 28 , perDay: 1500 //可选参数 每天限制次数 29 , perWeek: 3000 //可选参数 每周限制次数 30 ) 31 { 32 IpThrottling = true, //该值指示是否启用IP限制 33 ClientThrottling = true //该值指示是否启用客户端限制 34 }, 35 Repository = new CacheRepository(), //获取或设置限制度量存储。 36 //QuotaExceededMessage = JsonConvert.SerializeObject(json.msg), 37 QuotaExceededContent = (l, obj) => //违反限流事件 38 { //API calls quota exceeded! maximum admitted {0} per {1} 39 40 var json = new {message = $"系统检测您当前操作非人类,{l}/{obj}" }; 41 return (json); 42 } 43 }); 44 #endregion
第三步:测试
https://www.cnblogs.com/fger/p/11119566.html --有关WebApiThrottle 可查看此篇文章
https://www.cnblogs.com/SzeCheng/p/5407316.html --有关WebApiThrottle 可查看此篇文章
End