AWS WAF實戰、優勢對比和缺陷解決

文章目錄

    • 挑戰和目標
    • AWS WAF的優勢
    • AWS WAF的不足
    • 我是怎么做的?
    • 什么是比較好的AWS WAF設計?

筆者為了解決公司Web站點防御性問題,較為深入的研究AWS WAF的相關規則。面對上千萬的沖突,筆者不得設計出一種能漂亮處理沖突數據WAF規則。
AWS WAF

AWS WAF開發人員在線指南

挑戰和目標

筆者意圖引進WAF,但運維同學折騰了幾個月都沒有開啟WAF成功,面臨有以下挑戰和目標:

  • 解決大量與現有業務的沖突
  • 盡可能的Block掉攻擊流量
  • 風險操作統一管理(統一給一個標簽出來)方便我們監控

筆者只能接管WAF的配置權限,設計WAF規則,并最終解決了相關落地問題。

AWS WAF的優勢

  1. 高度可配置 相對阿里來說
  2. 純JSON語言 DSL(領域內語言)

AWS WAF的不足

  1. 缺乏可視化編輯能力
    非常容易漏,即一個請求沒有經過深度檢測就被放過的可能
    這里舉個例子,如果我們檢查一個請求具有客戶端特征,如果我們選擇了Accept就意味著這個請求將被特赦,無法再對其進行任何檢查。
    所以Accept動作是一個非常風險的設計動作。特別是當你的WAF已經設計比較復雜的時候。

  2. 對于官方的托管規則存在以下問題:
    三個問題其實是一個問題,如何關閉特定托管子項,AWS的托管規則子項僅存在這種選擇: Count,Accept,Block。想關都不關不掉。

    a. 無法重復兩次使用同一種托管規則
    b. 無法刪除被打上的標簽
    c. 無法關閉托管規則的子項:真乃一榮俱榮,一損俱損
    如果無法關閉特定標簽,后面就無法直接使用特定的命名空間進行判斷.
    因為拖管規則命名空間被一些需要根據業務關閉而又無法關閉的標簽給污染了,導致后面每次使用該命名空間要么都要判斷排除,要么就不能使用該命名空間,而需要獨立使用子項(可能包含了數十種子項).
    總之就是自虐.
    當然我們做了解決:通過自定義的Filter規則,來替代AWS的特定拖管規則,在Filter規則里對特定不符合業務的子托管規則進行剔除操作.

  3. 在線編輯功能,只能兩層(橫向)
    超出的部分就只能在線編輯,JSON的提示真是非人語言

我是怎么做的?

  1. 解決可視化問題
    制作了可視化工具,能解析AWS 的WAF JSON.
    特別是對Accept/Block/Count的目標和各規則之間關系進行了解析和展示.
  2. 關閉特定托管規則子項
    過自定義的Filter規則,來替代AWS的特定拖管規則,在Filter規則里對特定不符合業務的子托管規則進行剔除操作.
  3. 在線編輯只能兩層
    只能強行用復制粘貼方法了.在一個規則里測試好,再復制出來.
    幸虧我22層規則是縱向的,橫向的只有2-3層的樣子.

什么是比較好的AWS WAF設計?

我認為做到以下幾點可稱為好的AWS WAF設計:

  1. 流量過濾器
  2. 干掉純IP流量
    如果你的服務器不需要支持純IP連接的話.純IP真是萬惡之源.
  3. 給優先用戶一些標簽
    給登錄用戶一個標簽,給公司出去流量一個標簽
  4. 對托管規則做一個適合業務的裁剪(通過上面提到Filter規則)
  5. 集中管理
    也就是各層判斷根據判斷結果打標簽,一概不做Block.
    等所有標簽決策投票完畢后,有任何問題的,繼續走:Will_Ban層
    由決策層統一做判斷:
    比如是我們的保護路徑或者登錄用戶我們就納入Manual層,做記錄,放行
    其他自然流入最底的Tail_End進行Block.

最終筆者將以上5點擴展為具體規則,編寫一個22層的WAF來解決了相關問題。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/41277.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/41277.shtml
英文地址,請注明出處:http://en.pswp.cn/news/41277.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

Cocos2d 項目問題記錄

環境搭建 正常運行 Android 端的 Cocos2d 項目,本機至少需要 Android SDK、NDK 環境、Android Studio 項目報錯總結 CMake Error: CMake was unable to find a build program corresponding to "Ninja" 默認創建工程的 gradle.tools 版本為 3.1.0&…

微服務08-多級緩存

1.什么是多級緩存 傳統的緩存策略一般是請求到達Tomcat后,先查詢Redis,如果未命中則查詢數據庫,如圖: 存在下面的問題: ?請求要經過Tomcat處理,Tomcat的性能成為整個系統的瓶頸 ?Redis緩存失效時,會對數據庫產生沖擊 多級緩存就是充分利用請求處理的每個環節,分…

卷積操作后特征圖尺寸,感受野,參數量的計算

文章目錄 1、輸出特征圖的尺寸大小2、感受野的計算3、卷積核的參數量 1、輸出特征圖的尺寸大小 如果包含空洞卷積,即擴張率dilation rate不為1時: 2、感受野的計算 例如,圖像經過兩個3*3,步長為2的卷積后感受野為: co…

Centos7多臺服務器免密登錄

準備四臺服務器: docker0 docker1 docker2 docker3 在docker0服務器上生成公鑰和私鑰 [rootwww ~]# ssh-keygen -t rsa Generating public/private rsa key pair. Enter file in which to save the key (/root/.ssh/id_rsa): Created directory /root/.ssh. Enter passp…

在Gazebo中添加懸浮模型后,利用鍵盤控制其移動方法

前段時間寫了文章,通過修改sdf、urdf模型的方法,在Gazebo中添加懸浮模型方法 / Gazebo中模型如何不因重力下落:在Gazebo中添加懸浮模型方法 / Gazebo中模型如何不因重力下落:修改sdf、urdf模型_sagima_sdu的博客-CSDN博客 今天講…

Leetcode32 最長有效括號

給你一個只包含 ( 和 ) 的字符串&#xff0c;找出最長有效&#xff08;格式正確且連續&#xff09;括號子串的長度。 代碼如下&#xff1a; class Solution {public int longestValidParentheses(String str) {Stack<Integer> s new Stack<>();int res 0;int st…

GrapeCity Documents for Excel, Java Edition Crack

GrapeCity Documents for Excel, Java Edition Crack 增加了對SpreadJS.sjs文件格式的支持&#xff1a; 更快地將大型Microsoft Excel文件轉換為.sjs格式。 使用較小的占用空間保存導出的文件。 將Excel/SpreadJS功能導入SpreadJS/從SpreadJS導出。 從.sjs文件中壓縮的JSON文件…

JVM——JDK 監控和故障處理工具總結

文章目錄 JDK 命令行工具jps:查看所有 Java 進程jstat: 監視虛擬機各種運行狀態信息 jinfo: 實時地查看和調整虛擬機各項參數jmap:生成堆轉儲快照**jhat**: 分析 heapdump 文件**jstack** :生成虛擬機當前時刻的線程快照 JDK 可視化分析工具JConsole:Java 監視與管理控制臺連接…

手撕單鏈表

目錄 鏈表的概念和結構 單鏈表的實現 申請新結點 打印 尾插 頭插 尾刪 頭刪 ?編輯 查找 在pos位置前插入元素 在pos位置后插入元素 刪除pos位置的元素 刪除pos位置之后的位置的元素?編輯 完整代碼 SListNode.h SListNode.c 鏈表的概念和結構 鏈表是一種物理存儲…

【JavaSE】Java方法的使用

【本節目標】 1. 掌握方法的定義以及使用 2. 掌握方法傳參 3. 掌握方法重載 4. 掌握遞歸 目錄 1.方法概念及使用 1.1什么是方法(method) 1.2 方法定義 1.3 方法調用的執行過程 1.4 實參和形參的關系 2. 方法重載 2.1 為什么需要方法重載 2.2 方法重載概念 3. 遞歸 3.…

【uni-app報錯】獲取用戶收貨地址uni.chooseAddress()報錯問題

chooseAddress:fail the api need to be declared in …e requiredPrivateInf 原因&#xff1a; 小程序配置 / 全局配置 (qq.com) 解決&#xff1a; 登錄小程序后臺申請接口 按照流程申請即可 在項目根目錄中找到 manifest.json 文件&#xff0c;在左側導航欄選擇源碼視圖&a…

杭電比賽總結

我們的隊伍&#xff1a;team013 另外兩隊&#xff1a;team014、team015 ? 今天是我第一次打杭電&#xff0c;發現杭電多數都是猜結論題 先給一下我們的提交數據 Submit TimeProblem IDTimeMemoryJudge Status4:59:59101115 MS1692 KWrong Answer4:59:55101115 MS1684 KWrong…

Java算法_ 檢查對稱樹(LeetCode_Hot100)

題目描述&#xff1a;給你一個二叉樹的根節點 &#xff0c; 檢查它是否軸對稱。root 獲得更多&#xff1f;算法思路:代碼文檔&#xff0c;算法解析的私得。 運行效果 完整代碼 /*** 2 * Author: LJJ* 3 * Date: 2023/8/17 8:47* 4*/ public class SymmetricTree {static class…

vue之動態表單(優化)

代碼資源在這兒 ↑ vue之動態表單優化 vue2js動態表單優化vue3ts動態表單優化 vue2js動態表單優化 效果圖 目錄結構 五個文件的完整代碼: 以下是App.vue <template><div><router-view></router-view><Formpage /></div> </templa…

【LeetCode】647.回文子串

題目 給你一個字符串 s &#xff0c;請你統計并返回這個字符串中 回文子串 的數目。 回文字符串 是正著讀和倒過來讀一樣的字符串。 子字符串 是字符串中的由連續字符組成的一個序列。 具有不同開始位置或結束位置的子串&#xff0c;即使是由相同的字符組成&#xff0c;也會…

web連接桌面打開gptmap

一&#xff1a;環境配置 需要的材料&#xff1a; python-3.10.4 我使用的是這個版本的&#xff0c;3.8.10 該版本和以下版本組件組合&#xff0c;驗證過能正常運行&#xff08;python 3.6.8測試異常&#xff09; websockify 該項目有python版本和node js版本 noVNC 形式的app…

Qt Designer設計的界面如何顯示、即運行顯示窗口界面

首先利用Qt Designer設計.ui文件&#xff0c;然后采用Tools->External Tools->PyUIC轉換成.py文件。這個.py文件是.ui文件編譯而來的&#xff0c;將這種文件由.ui文件編譯而來的.py文件稱之為界面文件。由于界面文件每次編譯時候都會初始化&#xff0c;所以需要新建一個.…

Android 13 添加自定義分區,恢復出廠設置不被清除

需求: 客戶有些文件或數據,需要做得恢復出廠設置還存在,故需新增一個分區存儲客戶數據。 要求: a) 分區大小為50M b) 應用層可讀可寫 c) 恢復出廠設置后不會被清除 d) 不需要打包.img e) 不影響OTA升級 缺點: 1).通過代碼在分區創建目錄和文件,會涉及到SeLinux權限的修…

● 123.買賣股票的最佳時機III ● 188.買賣股票的最佳時機IV

123.買賣股票的最佳時機III class Solution { public:int maxProfit(vector<int>& prices) {vector<vector<int>>dp(prices.size(),vector<int>(5));int lenprices.size();if(len0)return 0;dp[0][0]0;dp[0][1]-prices[0];dp[0][2]0;dp[0][3]-pr…

LeetCode150道面試經典題-- 環形鏈表(簡單)

1.題目 給你一個鏈表的頭節點 head &#xff0c;判斷鏈表中是否有環。 如果鏈表中有某個節點&#xff0c;可以通過連續跟蹤 next 指針再次到達&#xff0c;則鏈表中存在環。 為了表示給定鏈表中的環&#xff0c;評測系統內部使用整數 pos 來表示鏈表尾連接到鏈表中的位置&…