AspNetCoreRateLimit應用於MVC項目求助

来源:https://www.cnblogs.com/ZYPLJ/archive/2023/05/07/17380401.html
-Advertisement-
Play Games

AspNetCoreRateLimit應用於MVC項目求助 前言 之前發過一篇文章: .NET Core WebApi介面ip限流實踐 - 妙妙屋(zy) - 博客園 (cnblogs.com) 然後應用在前後端分離項目這個組件是非常好用的。但應用於不分離的項目,比如我的個人博客就有點麻煩。 就是我 ...


AspNetCoreRateLimit應用於MVC項目求助

前言

之前發過一篇文章:

.NET Core WebApi介面ip限流實踐 - 妙妙屋(zy) - 博客園 (cnblogs.com)

然後應用在前後端分離項目這個組件是非常好用的。但應用於不分離的項目,比如我的個人博客就有點麻煩。

就是我的需求是評論介面限流,然後觸發限流後要回到文章頁面告訴用戶你觸發了限流,但是,使用這個組件,他會將返回信息以頁面的形式返回給你,我並不知道該如何去讓他回到文章頁面,也是琢磨了很久,用中間件去實現了這個效果,但是感覺不是很理想,如果有大佬知道更好的辦法,可以私信或評論,感激不盡。

實現的效果圖

image

評論介面

image

文章介面

image

_messages.Warning是博客開源作者封裝的提示信息組件,可以採用別的方式去提示,問題不大。這裡就是將從緩存中的提示信息提取出來,然後因為這裡用的是緩存,用session做的唯一值處理,所以用session去取出來,如果從緩存中查出來存在,則提示被限流。

代碼實現

原理就是把組件自帶的信息提示設置為空字元串,自己在中間件中去使用。

這是限流規則:

image

這裡參數就不做多的解釋,可以去看之前發佈的那篇文章。只要把Content設置為空字元串即可。

然後就開始去寫中間件去處理觸發了限流該怎麼做

需要註冊緩存服務

builder.Services.AddMemoryCache();

app.Use(async (context, next) =>
{
    var cache = context.RequestServices.GetRequiredService<IMemoryCache>();
    
    // 保存原始響應流
    var originalBody = context.Response.Body;
    
    // 創建一個新的響應流
    using var responseBody = new MemoryStream();
    context.Response.Body = responseBody;
    
    // 載入當前用戶的 Session 對象
    await context.Session.LoadAsync();
    
    await next.Invoke();
    
    if (context.Response.StatusCode == 429)
    {
        var referer = context.Request.Headers["Referer"].ToString();
        
        // 從 Session 中獲取一個字元串值
        var value = context.Session.GetString("key");
        if (string.IsNullOrEmpty(value))
        {
            // 如果 Session 中沒有值,則設置一個字元串值
            context.Session.SetString("key", "value");
        }
        var sessionId = context.Session.Id;
        if (!cache.TryGetValue("Errors", out Dictionary<string, string> errors))
        {
            errors = new Dictionary<string, string>();
            cache.Set("Errors", errors, TimeSpan.FromSeconds(10));
        }
        
        errors[sessionId] = "您的請求已被限流,請稍後再試。";
        
        // 重置響應流位置
        responseBody.Seek(0, SeekOrigin.Begin);
        
        // 讀取響應內容
        // var bodyText = new StreamReader(responseBody).ReadToEnd();
        
        // 設置新的響應流
        context.Response.Body = originalBody;
        
        // 設置新的響應狀態碼
        context.Response.StatusCode = 302;

        context.Response.Headers["Location"] = referer;
        
    }
    else
    {
        // 將響應流寫回到原始響應流中
        responseBody.Seek(0, SeekOrigin.Begin);
        await responseBody.CopyToAsync(originalBody);
        
    }
});

註意這個中間件處理要放在app.UseRateLimit();前面。

結尾

AspNetCoreRateLimit原本就講限流的ip存放在redis當中了的,但是我就是查不出來,如果能用該組件自帶的方法查詢出來,就不需要再寫一個中間件,當429的時候再用緩存存一次會話了。

總之暫且先用這種辦法吧,如果有更好的方法可以評論喲~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文首發於公眾號:Hunter後端 原文鏈接:Django筆記三十七之多資料庫操作(補充版) 這一篇筆記介紹一下 Django 里使用多資料庫操作。 在第二十二篇筆記中只介紹了多資料庫的定義、同步命令和使用方式,這一篇筆記作為補充詳細介紹如何對 Django 系統的多個資料庫進行針對的建表同步操作。 ...
  • 說明 使用 VLD 記憶體泄漏檢測工具輔助開發時整理的學習筆記。本篇介紹 VLD 源碼的調試。同系列文章目錄可見 《記憶體泄漏檢測工具》目錄 1. VLD 庫源碼調試步驟 以 vld2.5.1 版本為例,下載源碼 後,源碼包中各文件的用途可看本人另一篇博客 【VLD】源碼文件概覽。使用 VLD 進行泄漏 ...
  • 在Ubuntu下,使用VS Code來編輯代碼或進行開發非常方便,下麵記錄一下如何配置gcc/g++編譯器和GDB調試工具。 準備工作: 1. 安裝VS Code,過程略。 2. 為VS Code安裝C/C++ Extension Pack 擴展組件,其他插件會附帶安裝 3. Ubuntu系統自帶g ...
  • 分享一份讀者面試美團的面經,比較有參考性,感興趣的可以看看~ 一面 消息隊列如何保證可靠性 消息隊列如何保證消息冪等性 消息隊列的優缺點 為什麼用b+樹 聚集索引和主鍵區別,其他引擎怎麼做的 平時資料庫編碼 explain參數 http報文參數有哪些嗎? 做題,鏈表奇偶有序輸出 二面 自我介紹 有哪 ...
  • 本文是使用ChatCPT生成的,最終的代碼使用起來沒問題。代碼是通過兩輪對話完善的,後面把對話合併後跑不出理想效果就沒嘗試了。 第一輪對話 請求 c++11實現一個線程安全的map,使用方法與std::map保持一致,實現[]運算符 回覆 以下是一個簡單的線程安全的map實現,可以使用[]運算符來訪 ...
  • 1.打開QtCreator進行如下選擇。(開軟去官網下載即可,註冊郵箱可以斷網跳過) 第一步: 選擇Application 第二步:這裡文件名稱和路徑都不要有中文 第三步:選擇編譯模式 點擊下一步 第四步:選擇 Widget點擊下一步 第五步:運行工程,判斷是否創建成功 課堂小記: 1.析構函數不能 ...
  • ResellerClub購買功能變數名稱 ResellerClub 是一個全球領先的功能變數名稱註冊和網站托管解決方案提供商,屬於 Endurance International Group(EIG)旗下的一家品牌。ResellerClub 通過其領先的平臺和定製解決方案,為全球數百萬個網站提供了強大的托管和功能變數名稱服 ...
  • FreeSSL申請免費證書 FreeSSL 是一個免費證書和 SSL 證書管理平臺。旨在為個人和小型企業提供免費 SSL 證書,以加強他們的網站和應用程式的安全性。與傳統的 SSL 證書頒發機構不同,FreeSSL 使用自動化過程生成 SSL 證書,並提供一個管理面板,讓用戶可以輕鬆管理他們的證書和 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...