网络安全 | F5 WAF 黑白名单配置实践指南

news2025/4/25 12:32:25

关注: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

  1. 登录 F5 BIG-IP 设备:使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
  2. 导航到 Data Group
    • 在 Web 界面中,依次点击 Local Traffic > iRules > Data Group Lists
  3. 创建 Data Group
    • 点击 Create 按钮,创建一个新的 Data Group。
    • 名称:为 Data Group 设置一个易于识别的名称,例如 whitelist_ips
    • 类型:选择 address 类型(用于存储 IP 地址)。
    • 添加条目:输入需要加入白名单的 IP 地址或子网,例如 192.168.1.0/24

创建 iRules

  1. 登录 F5 BIG-IP 设备:使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
  2. 导航到 iRules
    • 在 Web 界面中,依次点击 Local Traffic > iRules
  3. 创建 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 到虚拟服务器

  1. 导航到虚拟服务器

    • 在 F5 管理界面中,导航到 Local Traffic > Virtual Servers > Virtual Server List
    • 选择需要应用黑名单规则的虚拟服务器。
  2. 添加 iRules

    • 在虚拟服务器的 Resources > iRules 部分,点击 Manage
    • 在弹出的窗口中,选择刚刚创建的 whitelist_rule,然后点击 Add

白名单配置流程

  1. 创建 Data Group
    • 创建一个名为 whitelist_ips 的 Data Group,类型为 address,并添加需要白名单的 IP 地址或子网。
  2. 创建 iRule
    • 编写 iRule 脚本,使用 class match 命令检查客户端 IP 是否在 whitelist_ips 中。
    • 如果客户端 IP 在白名单中,允许访问;否则,拒绝访问。
  3. 应用 iRule
    • 将创建的 iRule 应用到相应的虚拟服务器(Virtual Server)上。

黑名单配置

创建 Data Group

Data Group 是 F5 BIG-IP 中用于存储一组数据(如 IP 地址、字符串等)的工具,可以在 iRules 中方便地引用这些数据。

  1. 登录 F5 BIG-IP 设备

    • 使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
  2. 创建 Data Group

    • 导航到 Local Traffic > iRules > Data Group Lists
    • 点击 Create 按钮,创建一个新的 Data Group。
    • 名称:输入一个易于识别的名称,例如 blacklist_ips
    • 类型:选择 address 类型(用于存储 IP 地址)。
    • 添加条目:输入需要加入黑名单的 IP 地址或子网,例如 192.168.1.0/24

创建 iRules

  1. 登录 F5 BIG-IP 设备

    • 使用管理员账户登录到 F5 BIG-IP 设备的管理界面。
  2. 创建 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 到虚拟服务器

  1. 导航到虚拟服务器

    • 在 F5 管理界面中,导航到 Local Traffic > Virtual Servers > Virtual Server List
    • 选择需要应用黑名单规则的虚拟服务器。
  2. 添加 iRules

    • 在虚拟服务器的 Resources > iRules 部分,点击 Manage
    • 在弹出的窗口中,选择刚刚创建的 blacklist_rule,然后点击 Add

黑名单配置流程

  1. 创建 Data Group
    • 创建一个名为 blacklist_ips 的 Data Group,类型为 address,并添加需要白名单的 IP 地址或子网。
  2. 创建 iRule
    • 编写 iRule 脚本,使用 class match 命令检查客户端 IP 是否在 blacklist_ips 中。
    • 如果客户端 IP 在白名单中,允许访问;否则,拒绝访问。
  3. 应用 iRule
    • 将创建的 iRule 应用到相应的虚拟服务器(Virtual Server)上。

注意事项

  1. 性能优化:合理配置 Data Group 和 iRules,避免过多的匹配操作影响性能。
  2. 定期更新:根据实际情况定期更新 Data Group 中的 IP 地址,确保黑白名单的有效性。
  3. 测试验证:在生产环境中应用新的规则之前,建议在测试环境中进行充分的测试,以确保规则的正确性和稳定性。

总结

  通过结合 Data Group 和 iRules,F5 WAF 的黑白名单功能可以实现更灵活、更高效的流量控制策略。合理使用这些工具,不仅可以提高系统的安全性,还可以优化性能,确保业务的平稳运行。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2342420.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MyBatis操作数据库---从入门到理解

文章目录 关于MyBatis操作数据库MyBatis⼊⻔(使用)Mybatis操作数据库的步骤:配置数据库连接字符串使⽤MyBatis完成简单的增删改查操作注解xml 单元测试开启驼峰命名(推荐) 打印日志 关于MyBatis操作数据库 在之前的学习,我们了解到web应⽤程…

【HFP】蓝牙语音通话控制深度解析:来电拒接与通话终止协议

目录 一、来电拒接的核心流程与信令交互 1.1 拒接场景的分类与触发条件 1.2 HF 端拒接流程 1.3 AG 端拒接流程 二、通话终止流程:主动断开与异常中断 2.1 终止场景的界定 2.2 HF 端终止流程 2.3 AG 端终止流程 三、信令协议的核心要素:AT 命令与…

使用QML Tumbler 实现时间日期选择器

目录 引言相关阅读项目结构示例实现与代码解析示例一:时间选择器(TimePicker)示例二:日期时间选择器(DateTimePicker) 主窗口整合运行效果总结下载链接 引言 在现代应用程序开发中,时间与日期选…

智能吸顶灯/摄影补光灯专用!FP7195双通道LED驱动,高效节能省空间 !

一、双路调光技术背景与市场需求 随着LED照明技术的快速发展和智能照明需求的激增,双路调光技术正成为照明行业的重要发展方向。传统单路调光方案只能实现整体亮度的统一调节,而双路调光则能够实现对两个独立通道的精确控制。今天,由我来为大…

YOLOv11改进-双Backbone架构:利用双backbone提高yolo11目标检测的精度

一、引言:为什么我们需要双Backbone? 在目标检测任务中,YOLO系列模型因其高效的端到端检测能力而备受青睐。然而,传统YOLO模型大多采用单一Backbone结构,即利用一个卷积神经网络(CNN)作为特征提…

《逃离云端束缚,拥抱GPT本地部署》

《逃离云端束缚,拥抱GPT本地部署》 一、GPT 热潮与本地部署的兴起 自 OpenAI 推出 ChatGPT 以来,全球范围内掀起了一股人工智能的热潮,其强大的自然语言处理能力和广泛的应用场景,让人们对人工智能的未来充满了想象。GPT(Generative Pretrained Transformer)作为一种基于…

头歌之动手学人工智能-机器学习 --- PCA

目录 第1关:维数灾难与降维 第2关:PCA算法流程 任务描述 编程要求 测试说明 第3关:sklearn中的PCA 任务描述 编程要求 测试说明 第1关:维数灾难与降维 第2关:PCA算法流程 任务描述 本关任务:补充…

研0调研入门

一、Web of Science 使用教程 1. 访问与注册 访问入口:通过高校图书馆官网进入(需IP权限),或直接访问 Web of Science官网。注册/登录:若机构已订阅,用学校账号登录;个人用户可申请试用或付费…

神经网络基础[ANN网络的搭建]

神经网络 人工神经网络( Artificial Neural Network, 简写为ANN)也简称为神经网络(NN),是一种模仿生物神经网络结构和功能的计算模型。各个神经元传递复杂的电信号,树突接收到输入信号&#xf…

五、web自动化测试01

目录 一、HTML基础1、HTML介绍2、常用标签3、基础案例3.1 前端代码3.2 自动化测试 二、CSS定位1、css介绍2、案例3、代码优化 三、表单自动化1、案例2、元素属性定位 四、后台基础数据自动化1、登录1.1 id与class定位1.2 定位一组元素 2、商品新增 一、HTML基础 可参考学习 链…

数据库监控 | MongoDB监控全解析

PART 01 MongoDB:灵活、可扩展的文档数据库 MongoDB作为一款开源的NoSQL数据库,凭借其灵活的数据模型(基于BSON的文档存储)、水平扩展能力(分片集群)和高可用性(副本集架构)&#x…

STM32F407使用ESP8266实现阿里云OTA(中)

文章目录 前言一、程序分析二、程序讲解1. main函数2. Get_Version()函数3. esp_Init()函数4. Check_Updata()函数结语前言 从上一章STM32F407使用ESP8266实现阿里云OTA(上)中我们已经对连接阿里云和从阿里云获取升级包的流程非常的熟悉了。所以本章我们进行STM32的程序开发…

微信小程序 tabbar底部导航栏

官方文档:https://developers.weixin.qq.com/miniprogram/dev/reference/configuration/app.html#tabBar 一、常规菜单格式 在app.json 文件中配置,其他关键点详见官方文档,后续更新不规则图标的写法

Unity InputSystem触摸屏问题

最近把Unity打包后的windows软件放到windows触摸屏一体机上测试,发现部分屏幕触摸点击不了按钮,测试了其他应用程序都正常。 这个一体机是这样的,一个电脑机箱,外接一个可以触摸的显示屏,然后UGUI的按钮就间歇性点不了…

Linux Awk 深度解析:10个生产级自动化与云原生场景

看图猜诗,你有任何想法都可以在评论区留言哦~ 摘要 Awk 作为 Linux 文本处理三剑客中的“数据工程师”,凭借字段分割、模式匹配和数学运算三位一体的能力,成为处理结构化文本(日志、CSV、配置文件)的终极工具。本文聚…

免费版还是专业版?Dynadot 域名邮箱服务选择指南

关于Dynadot Dynadot是通过ICANN认证的域名注册商,自2002年成立以来,服务于全球108个国家和地区的客户,为数以万计的客户提供简洁,优惠,安全的域名注册以及管理服务。 Dynadot平台操作教程索引(包括域名邮…

旋转磁体产生的场-对导航姿态的影响

pitch、yaw、roll是描述物体在空间中旋转的术语,通常用于计算机图形学或航空航天领域中。这些术语描述了物体绕不同轴旋转的方式: Pitch(俯仰):绕横轴旋转,使物体向前或向后倾斜。俯仰角度通常用来描述物体…

Day11(回溯法)——LeetCode79.单词搜索

1 前言 今天主要刷了一道热题榜中回溯法的题,现在的计划是先刷热题榜专题吧,感觉还是这样见效比较快。因此本文主要介绍LeetCode79。 2 LeetCode79.单词搜索(LeetCode79) OK题目描述及相关示例如下: 2.1 题目分析解决及优化 感觉回溯的方…

PostgreSQL 分区表——范围分区SQL实践

PostgreSQL 分区表——范围分区SQL实践 1、环境准备1-1、新增原始表1-2、执行脚本新增2400w行1-3、创建pg分区表-分区键为创建时间1-4、创建24年所有分区1-5、设置默认分区(兜底用)1-6、迁移数据1-7、创建分区表索引 2、SQL增删改查测试2-1、查询速度对比…

SpringCloud 微服务复习笔记

文章目录 微服务概述单体架构微服务架构 微服务拆分微服务拆分原则拆分实战第一步:创建一个新工程第二步:创建对应模块第三步:引入依赖第四步:被配置文件拷贝过来第五步:把对应的东西全部拷过来第六步:创建…