网络安全 | F5 WAF 黑白名单配置实践指南
关注:CodingTechWork
引言
在现代网络安全架构中,F5 Web Application Firewall (WAF) 是保护 Web 应用免受攻击的重要工具。F5 WAF 提供了强大的黑白名单功能,结合 Data Group 和 iRules,可以实现更灵活、更高效的流量控制策略。本文将详细介绍如何利用 F5 官方功能,结合 Data Group 和 iRules 配置黑白名单。
F5 WAF 黑白名单功能概述
F5 WAF 的黑白名单功能允许管理员根据 IP 地址、URL 或其他条件对流量进行分类和控制。通过将特定的 IP 地址或子网添加到白名单中,可以确保这些流量不会被误拦截;而将已知的恶意 IP 地址添加到黑名单中,则可以有效阻止这些流量。
Data Group 的创建与管理
Data Group 是 F5 提供的一种数据管理工具,用于存储一组相关的数据元素(如 IP 地址、字符串等)。通过 Data Group,可以方便地在 iRules 中引用这些数据,从而简化规则的编写。
iRules 的编写与应用
iRules 是 F5 提供的一种基于 TCL 语言的脚本工具,用于自定义流量处理逻辑。通过 iRules,可以实现复杂的流量控制策略。
白名单配置
创建 Data Group
- 登录 F5 BIG-IP 设备:使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
- 导航到 Data Group:
- 在 Web 界面中,依次点击 Local Traffic > iRules > Data Group Lists。
- 创建 Data Group:
- 点击 Create 按钮,创建一个新的 Data Group。
- 名称:为 Data Group 设置一个易于识别的名称,例如
whitelist_ips
。 - 类型:选择
address
类型(用于存储 IP 地址)。 - 添加条目:输入需要加入白名单的 IP 地址或子网,例如
192.168.1.0/24
。
创建 iRules
- 登录 F5 BIG-IP 设备:使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
- 导航到 iRules:
- 在 Web 界面中,依次点击 Local Traffic > iRules。
- 创建 iRules:
- 点击 Create 按钮,创建一个新的 iRule。
- 名称:为 iRule 设置一个易于识别的名称,例如
whitelist_rule
。 - 内容:编写 iRule 脚本,使用
class match
命令引用 Data Group。
以下是一个简单的 iRule 示例,用于检查客户端 IP 是否在白名单中:
when CLIENT_ACCEPTED {if { [class match [IP::remote_addr] equals whitelist_ips] } {# 如果 IP 在白名单中,允许访问pool whitelist_pool} else {# 如果 IP 不在白名单中,拒绝访问drop}
}
应用 iRules 到虚拟服务器
-
导航到虚拟服务器:
- 在 F5 管理界面中,导航到 Local Traffic > Virtual Servers > Virtual Server List。
- 选择需要应用黑名单规则的虚拟服务器。
-
添加 iRules:
- 在虚拟服务器的 Resources > iRules 部分,点击 Manage。
- 在弹出的窗口中,选择刚刚创建的
whitelist_rule
,然后点击 Add。
白名单配置流程
- 创建 Data Group:
- 创建一个名为
whitelist_ips
的 Data Group,类型为address
,并添加需要白名单的 IP 地址或子网。
- 创建一个名为
- 创建 iRule:
- 编写 iRule 脚本,使用
class match
命令检查客户端 IP 是否在whitelist_ips
中。 - 如果客户端 IP 在白名单中,允许访问;否则,拒绝访问。
- 编写 iRule 脚本,使用
- 应用 iRule:
- 将创建的 iRule 应用到相应的虚拟服务器(Virtual Server)上。
黑名单配置
创建 Data Group
Data Group 是 F5 BIG-IP 中用于存储一组数据(如 IP 地址、字符串等)的工具,可以在 iRules 中方便地引用这些数据。
-
登录 F5 BIG-IP 设备:
- 使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
-
创建 Data Group:
- 导航到 Local Traffic > iRules > Data Group Lists。
- 点击 Create 按钮,创建一个新的 Data Group。
- 名称:输入一个易于识别的名称,例如
blacklist_ips
。 - 类型:选择
address
类型(用于存储 IP 地址)。 - 添加条目:输入需要加入黑名单的 IP 地址或子网,例如
192.168.1.0/24
。
创建 iRules
-
登录 F5 BIG-IP 设备:
- 使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
-
创建 iRules:
- 导航到 Local Traffic > iRules。
- 点击 Create 按钮,创建一个新的 iRule。
- 名称:输入一个易于识别的名称,例如
blacklist_rule
。 - 内容:编写 iRule 脚本,使用
class match
命令引用 Data Group。
以下是一个简单的 iRule 示例,用于检查客户端 IP 是否在黑名单中:
when CLIENT_ACCEPTED {if { [class match [IP::client_addr] equals blacklist_ips] } {# 如果 IP 在黑名单中,拒绝访问log local0. "Dropped connection from [IP::client_addr]: IP is blacklisted."drop}
}
应用 iRules 到虚拟服务器
-
导航到虚拟服务器:
- 在 F5 管理界面中,导航到 Local Traffic > Virtual Servers > Virtual Server List。
- 选择需要应用黑名单规则的虚拟服务器。
-
添加 iRules:
- 在虚拟服务器的 Resources > iRules 部分,点击 Manage。
- 在弹出的窗口中,选择刚刚创建的
blacklist_rule
,然后点击 Add。
黑名单配置流程
- 创建 Data Group:
- 创建一个名为
blacklist_ips
的 Data Group,类型为address
,并添加需要白名单的 IP 地址或子网。
- 创建一个名为
- 创建 iRule:
- 编写 iRule 脚本,使用
class match
命令检查客户端 IP 是否在blacklist_ips
中。 - 如果客户端 IP 在白名单中,允许访问;否则,拒绝访问。
- 编写 iRule 脚本,使用
- 应用 iRule:
- 将创建的 iRule 应用到相应的虚拟服务器(Virtual Server)上。
注意事项
- 性能优化:合理配置 Data Group 和 iRules,避免过多的匹配操作影响性能。
- 定期更新:根据实际情况定期更新 Data Group 中的 IP 地址,确保黑白名单的有效性。
- 测试验证:在生产环境中应用新的规则之前,建议在测试环境中进行充分的测试,以确保规则的正确性和稳定性。
总结
通过结合 Data Group 和 iRules,F5 WAF 的黑白名单功能可以实现更灵活、更高效的流量控制策略。合理使用这些工具,不仅可以提高系统的安全性,还可以优化性能,确保业务的平稳运行。
相关文章:
网络安全 | F5 WAF 黑白名单配置实践指南
关注:CodingTechWork 引言 在现代网络安全架构中,F5 Web Application Firewall (WAF) 是保护 Web 应用免受攻击的重要工具。F5 WAF 提供了强大的黑白名单功能,结合 Data Group 和 iRules,可以实现更灵活、更高效的流量控制策略。…...
黑马 redis面试篇笔记
redis主从 version: "3.2"services:r1:image: rediscontainer_name: r1network_mode: "host"entrypoint: ["redis-server", "--port", "7001"]r2:image: rediscontainer_name: r2network_mode: "host"entrypoint:…...
报错_NoSuchMethodException: cn.mvc.entity.User.<init>()
org.springframework.beans.BeanInstantiationException: Failed to instantiate [cn.mvc.entity.User]: No default constructor found; nested exception is java.lang.NoSuchMethodException: cn.mvc.entity.User.<init>() 添加一个无参的构造器即可! pub…...
【无人机】无人机遥控器设置与校准,飞行模式的选择,无线电控制 (RC) 设置
目录 1、遥控器校准 1.1、校准步骤 2、飞行模式选择,遥控器通道映射 2.1、配置步骤 1、遥控器校准 在校准无线电系统之前,必须连接/绑定接收器和发射器。绑定发射器和接收器对的过程是特定于硬件的(有关说明,请参阅 RC 手册&…...
基于 EFISH-SBC-RK3588 的无人机环境感知与数据采集方案
一、核心硬件架构设计 高性能算力引擎(RK3588 处理器) 异构计算架构:集成 8 核 CPU(4Cortex-A762.4GHz 4Cortex-A551.8GHz),支持动态调频与多任务并行处理,单线程性能较传统四核方案…...
上岸率85%+,25西电先进材料与纳米科技学院(考研录取情况)
1、先进材料与纳米科技学院各个方向 2、先进材料与纳米科技学院近三年复试分数线对比 学长、学姐分析 由表可看出: 1、材料科学与工程25年相较于24年上升10分,为290分 2、材料与化工(专硕)25年相较于24年下降20分,为…...
10天学会嵌入式技术之51单片机-day-7
第十六章 UART通信 16.1 UART 概述 16.1.1 前置基础 想要理解和使用 UART,需要先了解一些通讯领域的术语,如下 。 (1)串行通讯和并行通讯 串行通讯和并行通讯是数据传输的两种主要方式,两者的区别如下。 ÿ…...
w~视觉~合集3
我自己的原文哦~ https://blog.51cto.com/whaosoft/12327888 #几个论文 Fast Charging of Energy-dense Lithium-ion Batteries Real-time Short Video Recommendation on Mobile Devices Semantic interpretation for convolutional neural networks: What makes a ca…...
AI在论文评审中的应用与工具推荐
一、AI在论文评审中的核心应用场景 内容质量评估与逻辑校验 • 核心论点识别:AI可快速定位论文核心创新点,并验证其与文献综述、实验数据的逻辑一致性(如知网研学的“文献矩阵分析”功能)。 • 方法论合理性检测:自动识…...
怎样记忆Precision、Recall?
首先,明确符号: TP(True Posive):标签为正,预测为正 TN(True Negative):标签为负,预测为负 FP(False Positive):标签为负,预测为正 FN(False Negative):标签为正…...
【刷题】第三弹——二叉树篇(上)
文章目录 一.相同的树二. 另一棵树的子树三. 翻转二叉树四. 对称二叉树五. 平衡二叉树六. 二叉搜索树七. 二叉树的遍历 一.相同的树 检查两棵树是否相同 思路: 1.先比较结构 结构不一样直接false 2.结构一样,在比较值 public boolean isSameTree(TreeNode p, TreeNode q) {if…...
【Canvas与标志】红黄渐变阴影太极图
【成图】 120*120的png图标 大小图: 【代码】 <!DOCTYPE html> <html lang"utf-8"> <meta http-equiv"Content-Type" content"text/html; charsetutf-8"/> <head><title>红黄渐变阴影太极图 Draft1&l…...
express的中间件,全局中间件,路由中间件,静态资源中间件以及使用注意事项 , 获取请求体数据
Express 中间件系统 的详细讲解,包括全局中间件、路由中间件、静态资源中间件、请求体解析中间件,以及使用注意事项👇 🌐 一、什么是中间件(Middleware)? 中间件是 函数,在请求到达…...
大数据去重
实验4 大数据去重 1.实验目的 通过Hadoop数据去重实验,学生可以掌握准备数据、伪分布式文件系统配置方法,以及在集成开发环境Eclipse中实现Hadoop数据去重方法。 2.实验要求 了解基于Hadoop处理平台的大数据去重过程,理解其主要功能&…...
高功率激光输出稳定性不足?OAS 光学软件来攻克
法布里珀罗干涉仪设计案例 简介 法布里珀罗干涉仪作为一种高分辨率光学仪器,基于多光束干涉原理构建。其核心结构由两块高度平行的反射镜组成谐振腔,当光进入该谐振腔后,会在镜面间进行多次反射。在这一过程中,透射光会形成干涉条…...
基于大模型的结肠癌全病程预测与诊疗方案研究
目录 一、引言 1.1 研究背景与意义 1.2 研究目的与创新点 二、结肠癌概述 2.1 流行病学特征 2.2 发病机制与危险因素 2.3 临床症状与诊断方法 三、大模型技术原理与应用现状 3.1 大模型的基本原理 3.2 在医疗领域的应用情况 3.3 在结肠癌预测中的潜力分析 四、术前…...
【Hive入门】Hive查询语言(DQL)完全指南:从基础查询到高级分析
目录 1 Hive查询执行架构全景 2 SELECT基础查询详解 2.1 基本查询结构 2.2 条件查询流程图 3 聚合函数与GROUP BY实战 3.1 聚合执行模型 3.2 GROUP BY数据流 4 排序操作深度解析 4.1 ORDER BY执行流程 4.2 排序算法对比 5 高级技巧与注意事项 5.1 嵌套查询与CTE 5.…...
【学习笔记】文件包含漏洞--相关习题
第一关 伪协议 用代码执行命令查看目录所含文件,发现flag.php 法一 题目代码含有include,写入文件包含指令: php://filter/readconvert.base64-encode/resourceflag.php 解码即可得到flag。 法二 法三 法二可以用php://input&…...
蓝桥杯 20. 压缩变换
压缩变换 原题目链接 题目描述 小明最近在研究压缩算法。他知道,压缩时如果能够使数值很小,就能通过熵编码得到较高的压缩比。然而,要使数值变小是一个挑战。 最近,小明需要压缩一些正整数序列,这些序列的特点是&a…...
BY免费空间去掉?i=1
BY免费空间去掉?i1 使用说明 支持域名:tae.dpdns.org 前提绑定主机,申请主机–控制面板选择–子域名,绑定xxx.tae.dpdns.org子域名 默认开启DDoS防御,无防火墙规则,建议用.htaccess来防御 默认去掉访问统计?i1 …...
中篇:深入剖析 L2CAP 与 ATT 协议模块(约5000字)
引言 在 BLE 协议栈中,L2CAP 与 ATT 承担了关键的数据分发、协议复用与属性访问职责。对多协议并存和大数据场景的应用,深入理解这两层协议的分片重组、流控机制、MTU/MTU 协商和 ATT 操作流程,对于提升系统性能与稳定性至关重要。本篇将全面拆解 L2CAP 与 ATT 的原理与实战…...
【C语言】C语言结构体:从基础到高级特性
前言 在C语言的世界里,结构体是一种强大而灵活的自定义数据类型,它能够将不同类型的数据组合在一起,形成一个逻辑上的整体。从简单的数据聚合到复杂的内存对齐优化,再到高效的位段操作,结构体在系统编程、嵌入式开发和…...
电控---JTAG协议
一、物理层架构与信号特性 1. 引脚定义与电气规范 核心引脚: TCK(测试时钟):频率范围0.1MHz至50MHz(如Xilinx Spartan-6支持25MHz),上升沿采样数据。TMS(测试模式选择)…...
FreeRTOS【3】任务调度算法
重要概念 在运行的任务,被称为"正在使用处理器",它处于运行状态。在单处理系统中,任何时间里只能有一个任务处于运行状态。 非运行状态的任务,它处于这 3 中状态之一:阻塞(Blocked)、暂停(Suspended)、就绪…...
高德地图API + three.js + Vue3基础使用与使用 + 标记不显示避坑
three.js小白的学习之路。 最近闲来无事,突然想起来之前好像项目有需求说是要将模型放在地图上。加上在浏览别的大佬写的博客时,也找到了一些大佬写的相关文章。基本上都是使用的高德地图开放平台的JS API。我也随之开启了自己的学习之路。 先简单学习…...
书籍推荐:《价值心法》一姜胡说
书名 :《价值心法》一姜胡说 摘录 每天问问自己,如果今天只做一件事,这件事是什么?找到它。拿出2—3个小时,专门处理这件事。其他所有事全部排在那2—3个小时之外。 集中一段时间用来做最重要的事。这段时…...
Linux GPIO驱动开发实战:Poll与异步通知双机制详解
1. 引言 在嵌入式Linux开发中,GPIO按键驱动是最基础也最典型的案例之一。本文将基于一个支持poll和异步通知双机制的GPIO驱动框架,深入剖析以下核心内容: GPIO中断与防抖处理环形缓冲区设计Poll机制实现异步通知(SIGIO)实现应用层交互方式 …...
x-cmd install | brows - 终端里的 GitHub Releases 浏览器,告别繁琐下载!
目录 核心功能与优势安装适用场景 还在为寻找 GitHub 项目的特定 Release 版本而苦恼吗?还在网页上翻来覆去地查找下载链接吗?现在,有了 brows,一切都将变得简单高效! brows 是一款专为终端设计的 GitHub Releases 浏览…...
一天学完Servlet!!!(万字总结)
文章目录 前言Servlet打印Hello ServletServlet生命周期 HttpServletRequest对象常用api方法请求乱码问题请求转发request域对象 HttpServletResponse对象响应数据响应乱码问题请求重定向请求转发与重定向区别 Cookie对象Cookie的创建与获取Cookie设置到期时间Cookie注意点Cook…...
c#-命名和书写规范
文章目录 1. 接口名称以大写 I 开头2. 属性类型以单词 Attribute 结尾3. 枚举类型对非标记使用单数名词,对标记使用复数名词4. 标识符不应包含两个连续下划线(__)字符5. 对变量、方法和类使用有意义的描述性名称6. 将 PascalCase 用于类名和方法名称7. 对方法参数和局部变量…...
【双指针】和为s的两个数字
57. 和为target的两个数字 剑指 Offer 57. 和为s的两个数字 输入一个递增排序的数组和一个数字target,在数组中查找两个数,使得它们的和正好是target。如果有多对数字的和等于target,则输出任意一对即可。 示例 1: 输入&…...
【Vue】TypeScript与Vue3集成
个人主页:Guiat 归属专栏:Vue 文章目录 1. 前言2. 环境准备与基础搭建2.1. 安装 Node.js 与 npm/yarn/pnpm2.2. 创建 Vue3 TypeScript 项目2.2.1. 使用 Vue CLI2.2.2. 使用 Vite(推荐)2.2.3. 目录结构简述 3. Vue3 TS 基础语法整…...
win11中wsl在自定义位置安装ubuntu20.04 + ROS Noetic
wsl的安装 环境自定义位置安装指定ubuntu版本VsCodeROS备份与重载备份重新导入 常用命令参考文章 环境 搜索 启用或关闭 Windows 功能 勾选这2个功能,然后重启 自定义位置安装指定ubuntu版本 从网上找到你所需要的相关wsl ubuntu版本的安装包,一般直…...
【数据可视化-29】食物营养成分数据可视化分析
🧑 博主简介:曾任某智慧城市类企业算法总监,目前在美国市场的物流公司从事高级算法工程师一职,深耕人工智能领域,精通python数据挖掘、可视化、机器学习等,发表过AI相关的专利并多次在AI类比赛中获奖。CSDN…...
手动实现legend 与 echarts图交互 通过js事件实现图标某项的高亮 显示与隐藏
通过html实现legend的样式 提供调用echarts的api实现与echarts图表交互的效果 实现饼图element实现类似于legend与echartstu表交互效果 效果图 配置代码 <template><div style"height: 400px; width: 500px;background-color: #CCC;"><v-chart:opti…...
C语言编程--16.删除链表的倒数第n个节点
题目: 给你一个链表,删除链表的倒数第 n 个结点,并且返回链表的头结点。 示例 1: 输入:head [1,2,3,4,5], n 2 输出:[1,2,3,5] 示例 2: 输入:head [1], n 1 输出:…...
centos7使用certbot完成nginx ssl证书续期
没有废话纯干货 yum源配置(配置好的可以跳过) #到/etc/yum.repos.d/下mkdir bak,将所用东西mv到bak下 cd /etc/yum.repos.d/ mkdir bak mv ./* bak/ wget https://mirrors.aliyun.com/repo/Centos-7.repo 没有安装nginx的话,配…...
ECharts学习之 toolbox 工具栏
toolbox: {show: true,feature: {//数据视图工具,可以展现当前图表所用的数据dataView: {title: "数据视图",readOnly: false, //是否不可编辑,即只读lang:[数据视图,关闭,刷新] //数据视图上有三个话术},magicType: {type: ["line"…...
修改el-select背景颜色
修改el-select背景颜色 /* 修改el-select样式--直接覆盖默认样式(推荐) */ ::v-deep .el-select .el-input__inner {background-color: #1d2b72 !important; /* 修改输入框背景色 */color: #fff; } ::v-deep .el-select .el-input__wrapper {background-…...
Qt 使用 MySQL 数据库的基本方法
在 Qt 中,使用 MySQL 数据库的基本方法主要是通过 QSqlDatabase、QSqlQuery 等类来进行数据库的连接、查询和数据操作。以下是 Qt 中连接和操作 MySQL 数据库的基本步骤。 1. 安装 MySQL 驱动 首先,确保您的 Qt 环境已经配置了 MySQL 驱动。通常&#…...
BLIP 系列论文(BLIP、BLIP-2、InstructBLIP)
BLIP BLIP 是 Salesforce 团队在多模态领域中的经典工作,影响力巨大,BLIP 系列包括:BLIP、BLIP-2、InstructBLIP。 BLIP 在多模态大模型之前,多模态领域中最流行的是视觉-语言预训练(Vision-Language Pre-training,…...
【玩转全栈】—— 无敌前端究极动态组件库--Inspira UI
目录 Inspira UI 介绍 配置环境 使用示例 效果: Inspira UI 学习视频: 华丽优雅 | Inspira UI快速上手_哔哩哔哩_bilibili 官网:https://inspira-ui.com/ Inspira UI 介绍 Inspira UI 是一个设计精美、功能丰富的用户界面库,专为…...
Java24新增特性
Java 24(Oracle JDK 24)作为Java生态的重要更新,聚焦AI开发支持、后量子安全、性能优化及开发者效率提升,带来20余项新特性和数千项改进。以下是核心特性的分类解析: 一、语言特性增强:简化代码与模式匹配 …...
Git多人协作与企业级开发模型
目录 1.多人协作一 2.多人协作二 3.远程分⽀删除后,本地gitbranch-a依然能看到的解决办法 4.企业级开发模型 4.1.Git的重要性 4.2.系统开发环境 4.3.Git 分⽀设计规范 1.多人协作一 ⽬前,我们所完成的⼯作如下: 基本完成Git的所有本…...
Android学习总结之扩展基础篇(一)
一、IdleHandler工作原理 1. IdleHandler 接口定义 IdleHandler 是 MessageQueue 类中的一个接口,定义如下: public static interface IdleHandler {/*** 当消息队列空闲时会调用此方法。* return 如果返回 true,则该 IdleHandler 会保留在…...
C语言教程(十六): C 语言字符串详解
一、字符串的表示 在C语言中,字符串是由一系列字符组成,并且以空字符 \0 作为结束标志。字符串通常用字符数组来表示。例如: char str[] {H, e, l, l, o, \0};也可以使用字符串字面量来初始化字符数组:char str[] "Hello&…...
Redis LFU 策略参数配置指南
一、基础配置步骤 设置内存上限 在 redis.conf 配置文件中添加以下指令,限制 Redis 最大内存使用量(例如设置为 4GB): maxmemory 4gb选择 LFU 淘汰策略 根据键的作用域选择策略: # 所有键参与淘汰 maxmemory-…...
Pikachu靶场-unsafe upfileupload
不安全的文件上传漏洞防御与对抗方式对照表 防御方式 防御实现 攻击者对抗方式 对抗原理 文件类型白名单验证 仅允许指定扩展名(如 .jpg, .png) if (!in_array($ext, [jpg, png])) { die(); } 伪造文件类型: 1. 修改文件头(…...
Python基础语法:查看数据的类型type(),数据类型转换,可变和不可变类型
目录 查看数据类型type() 使用type()语句查看数据的类型 变量无类型而数据有类型 数据类型转换 在字符串,整型,浮点数之间相互转换 可变类型和不可变类型 查看数据类型type() 使用type()语句查看数据的类型 Python中使用type(被查看数据的类型)语…...
高防IP是如何防护DDoS攻击和CC攻击的
高防IP是一种针对网络攻击(如DDoS和CC攻击)设计的防护服务,其核心原理是通过流量调度、智能清洗和分布式防护节点等技术,将恶意流量拦截在目标服务器之外。以下是其防护DDoS和CC攻击的具体机制: 一、防御DDoS攻击的机制…...