Node.JS教程36:开发一个WAF(Web应用防火墙)中间件!
防黑客,防攻击!
如果用Node.JS做Web服务,很多时候是会选择Express的。
本文,将展示如何如何实现一个WAF中间件。
WAF有什么用?
WAF即Web Application Firewall,Web应用防火墙,防攻击、防黑客的。
小提示:npm上,目前还没有专业的express中间件WAF,这可是稀缺的技术!
先看完整示例代码:
本示例,是一个带有WAF功能的Web应用。
内置的中间件部分,实现WAF的防护功能:
即,对发起的请求进行过滤,判断请求中是否有恶意行为。如果有,则不让中件间进行next(),请求也就被中断,达到防止攻击者入侵的目的。
WAF防护规则
攻击检测使用的是正则表达式,这是WAF常用的攻击检测方式。
规则逻辑暂且不详细探讨,因为它是正则表达式,如果详细讲述起来,恐怕得另多写三五篇文章了。
执行效果:
模拟访问发起攻击:
即在url中传入select*from admin语句,这是一句常见的SQL注入攻击语句。
可以看到,网站无法打开。在后台输出了拦截信息,并提示出触发了哪条WAF防护规则。
本文只做演示,仅检测了url路径。
那么本代码是可以括展的,可以检测cookie、user-agent、post数据等常见攻击点。
写成一个Express模块是完全可以的。