#!/usr/bin/env python ''' Copyright (C) 2020, WAFW00F Developers. See the LICENSE file for copying permission. ''' NAME = 'Greywizard (Grey Wizard)' def is_waf(self): # 定义用于检测是否存在特定 Web 应用防火墙(WAF)的方案列表。 schemes = [ # 检查响应头中的'Server'字段是否为'greywizard'。 self.matchHeader(('Server', 'greywizard')), # 检查响应内容中的标题标签()或 h1 到 h9 标签中是否包含'Grey Wizard'。 self.matchContent(r'<(title|h\d{1})>Grey Wizard'), # 检查响应内容中是否包含'contact the website owner or Grey Wizard'。 self.matchContent(r'contact the website owner or Grey Wizard'), # 检查响应内容中是否包含'We.ve detected attempted attack or non standard traffic from your ip address'。 self.matchContent(r'We.ve detected attempted attack or non standard traffic from your ip address') ] # 如果方案列表中的任何一个条件为真,则认为检测到了 WAF。 if any(i for i in schemes): return True else: return False