如何打造一款可靠的WAF

安全 应用安全
本篇文章从WAF产品研发的角度来YY如何实现一款可靠的WAF,灵感来自ModSecurity等,感谢开源。

之前写了一篇《WAF防御能力评测及工具》 ,是站在安全运维人员选型WAF产品的角度来考虑的(优先从测试角度考虑是前职业病,毕竟当过3年游戏测试!)。本篇文章从WAF产品研发的角度来YY如何实现一款可靠的WAF,灵感来自ModSecurity等,感谢开源。

本片文章包括三个主题

(1) WAF实现

WAF包括哪些组件,这些组件如何交互来实现WAF防御功能

(2)WAF规则(策略)维护

规则(策略)如何维护,包括获取渠道,规则测试方法以及上线效果评测

(3) WAF支撑

WAF产品的完善需要哪些信息库的支撑

一、WAF实现

WAF一句话描述,就是解析HTTP请求(协议解析模块),规则检测(规则模块),做不同的防御动作(动作模块),并将防御过程(日志模块)记录下来。 不管硬件款,软件款,云款,核心都是这个,而接下来围绕这句话来YY WAF的实现。 WAF的实现由五个模块(配置模块、协议解析模块、规则模块、动作模块、错误处理模块)组成

1. 配置模块

设置WAF的检测粒度,按需开启,如图所示

 

WAF的实现 - 碳基体 - 碳基体

 

2. 协议解析模块(重点)

协议解析的输出就是下一个模块规则检测时的操作对象,解析的粒度直接影响WAF防御效果。对于将WAF模块寄生于web 服务器的云WAF模式,一般依赖于web 服务器的解析能力。

 

WAF的实现 - 碳基体 - 碳基体

 

3. 规则模块(重点)

重点来了,这块是WAF的核心,我将这块又细分为三个子模块。

(1) 规则配置模块

IP黑白名单配置、 URL黑白名单配置、以及挑选合适的规则套餐。

 

WAF的实现 - 碳基体 - 碳基体

 

(2)规则解析模块

主要作用是解析具体的规则文件,规则***采用统一的规则描述语言,便于提供给第三方定制规则,ModSecurity这方面做得非常优秀。

规则文件由四部分组成,分为变量部分、操作符部分,事务函数部分与动作部分。

 

WAF的实现 - 碳基体 - 碳基体

 

 

WAF的实现 - 碳基体 - 碳基体

 

(3)规则检测模块

上一步我们设置了各种变量,接下来就是按照一定的逻辑来做加减乘除了。

 

WAF的实现 - 碳基体 - 碳基体

 

4. 动作模块(重点)

通过规则检测模块,我们识别了请求的好恶,接下来就是做出响应,量刑处理,不仅仅是拦截。

 

WAF的实现 - 碳基体 - 碳基体

 

5. 日志模块(重点)

日志处理,非常重要,也非常火热,内容丰富到完全可以从WAF独立出来形成单独的安全产品(e.g.日志宝)而采用提供接口的方式来支撑WAF。对于数据量巨大的云WAF,都会有单独的大数据团队来支撑架构这一块,包括数据存储(e.g. hdfs) ,数据传输(kafka),数据离线分析(hadoop/spark),数据实时分析(storm),数据关联分析(elasticsearch)等等,以后另开一篇单独说明。

 

WAF的实现 - 碳基体 - 碳基体

 

6. 错误处理模块

以上模块运行错误时的异常处理

二、WAF规则(策略)维护

 

WAF的实现 - 碳基体 - 碳基体

 

三、WAF支撑信息库

 

WAF的实现 - 碳基体 - 碳基体

 

以上支撑库几乎所有的安全人员都在重复地做,而资源没有共享的原因,一是内部不可说;二是没有采取统一的描述语言无法汇合,唉,安全从业人员的巴别塔。

四、补充知识(包括文章与代码)

想想写了这么多文章,自我感觉萌萌哒!

WAF相关

WAF防御能力评测及工具

ssdeep检测webshell

ModSecurity相关文章(我就是ModSecurity的死忠粉)

[科普文]ubuntu上安装Apache2+ModSecurity及自定义WAF规则

ModSecurity SecRule cheatsheets

ModSecurity CRS 笔记、WAF防御checklist,及WAF架构的一些想法

ModSecurity 晋级-如何调用lua脚本进行防御快速入门

ModSecurity 白名单设置

指纹识别

Web应用指纹识别

FingerPrint

IP相关

使用免费的本地IP地理库来定位IP地理位置-GeoIP lookup

获得IP的地理位置信IP Geolocation及IP位置可视化

IP地理信息离线获取脚本

IP地理信息在线获取脚本

识别搜索引擎脚本

判断使用哪家CDN脚本

代理类型判断脚本 Proxy探测脚本与HTTP基本认证暴力破解脚本

CDN架构

网站负载均衡技术读书笔记与站长产品的一点想法

正则优化

NFA引擎正则优化TIPS、Perl正则技巧及正则性能评测方法

HTTP发包工具

HTTP.pl——通过HTTP发包工具了解HTTP协议

HTTP发包工具 -HTTPie

WAF实现的思维导图

参考:

ModSecurity Handbook

第八、九、十,十一我是反复看,每次都有新的灵感,第14、15章是当成新华字典看的,以免遗忘。

《 Web Application Defenders Cookbook Battling Hackers and Protecting Users 》 (红宝书,还在看)

原文地址:http://danqingdani.blog.163.com/blog/static/1860941952014101723845500/

责任编辑:蓝雨泪 来源: FreeBuf
相关推荐

2022-03-04 09:05:55

StarRocks数据湖数据质量

2015-11-27 09:18:11

AngularJSWeb应用

2017-01-13 08:37:57

PythonAlphaGoMuGo

2022-04-30 09:49:58

终端工具插件

2015-08-18 09:11:34

杜长伟APP

2015-08-10 11:41:00

SQL注入SQL注入工具Sqlmapi

2021-11-17 15:36:04

鸿蒙HarmonyOS应用

2020-12-03 09:00:02

Java外卖系统

2015-07-28 10:51:03

私有云AWS企业IT

2018-06-05 14:21:33

NewSQLMySQLRadonDB

2020-12-07 11:50:14

Java学习系统eclipse

2020-03-12 09:20:41

微软浏览器Windows

2019-05-06 11:49:10

DomTerm终端模拟器Linux

2016-12-08 11:49:03

APPRetrofitRxJava

2017-03-06 11:02:59

产品软件Power Desig

2023-07-03 08:25:54

2015-01-28 13:14:32

2009-05-11 15:12:03

网管软件产品摩卡软件

2014-06-20 10:32:42

APP上瘾设计

2022-04-18 19:02:53

chrome扩展浏览器
点赞
收藏

51CTO技术栈公众号