当前位置: 首页 > news >正文

后端 .net7 Minimal API 限流中间件(微信小程序无师自通十)

        我的微信小程序使用.net7 Minimal API 作为后端,当服务器摆上公网后,可以观察到很多的攻击行为和暴力访问。所以,我需要使用微软的限流中间件部署相应的功能在服务器上

关键字:

AddFixedWindowLimiter

using Microsoft.AspNetCore.RateLimiting;

using System.Threading.RateLimiting;

后端 .net7 Minimal API 限流中间件的说明出现在微软ASP.NET Core 7.0的说明中:

ASP.NET Core 中的速率限制中间件 | Microsoft Learn

在文章的末尾,有一个更详细的blog说明:

ASP.NET Core rate limiting middleware in .NET 7 - Maarten Balliauw {blog}

        与其他中间件非常相似,要启用ASP。. NET Core速率限制中间件,您必须将所需的服务添加到服务集合中,然后为所有请求管道启用中间件。让我们添加一个简单的速率限制器,将所有请求限制为每分钟10个,每个经过身份验证的用户名(或主机名,如果未经过身份验证):

var builder = WebApplication.CreateBuilder(args);builder.Services.AddRateLimiter(options =>
{options.GlobalLimiter = PartitionedRateLimiter.Create<HttpContext, string>(httpContext =>RateLimitPartition.GetFixedWindowLimiter(partitionKey: httpContext.User.Identity?.Name ?? httpContext.Request.Headers.Host.ToString(),factory: partition => new FixedWindowRateLimiterOptions{AutoReplenishment = true,PermitLimit = 10,QueueLimit = 0,Window = TimeSpan.FromMinutes(1)}));
});// ...var app = builder.Build();// ...app.UseRouting();
app.UseRateLimiter();app.MapGet("/", () => "Hello World!");app.Run();

http://www.lryc.cn/news/126159.html

相关文章:

  • 背上沉重的书包准备面试之react篇
  • OpenCV-Python中的图像处理-霍夫变换
  • W5500-EVB-PICO做UDP Client进行数据回环测试(八)
  • npm install 中 --save 和 --save-dev 是什么?
  • 【Nginx17】Nginx学习:目录索引、字符集与浏览器判断模块
  • CA/TA开发编程实战-视频课程
  • (7)(7.1) 使用航点和事件规划任务
  • OCR相关模块——版面分析技术、表格文本识别
  • mov转mp4格式怎么转?
  • SSL握手协议相关概念
  • idea 打开java项目后新建的模块中,java文件夹需要变成蓝色,以及resources文件夹变成三条杠的
  • 【Docker】Docker network之bridge、host、none、container以及自定义网络的详细讲解
  • 滑模控制器理论推导和matlab/simulink实例分享
  • git 操作
  • 自建hexo博客并将原有的文章发布其上
  • 【双指针_和为 s 的两个数_C++】
  • HTML5的介绍和基本框架
  • 代码随想录算法训练营第58天|动态规划part15|392.判断子序列、115.不同的子序列
  • 日常BUG——普通页面跳转tabbar页面报错
  • SpringBoot复习:(48)RedisAutoConfiguration自动配置类
  • 软硬件免费,服务收费:网络安全商业模式正在被颠覆
  • 变形金刚:从零开始【01/2】
  • Opencv特征检测之ORB算法原理及应用详解
  • 【es6】函数柯里化(Currying)
  • 线上多域名实战
  • 【C语言】上手实验
  • 设计HTML5表单
  • 使用Kaptcha生成验证码
  • 【vue】vue中的插槽以及使用方法
  • javaScript:分支语句的理解与使用(附带案例)