#!/usr/bin/env python ''' Copyright (C) 2020, WAFW00F Developers. See the LICENSE file for copying permission. ''' NAME = 'CrawlProtect (Jean-Denis Brun)' def is_waf(self): # 定义用于检测是否存在特定 Web 应用防火墙(WAF)的方案列表。 schemes = [ # 检查 Cookie 是否以'crawlprotecttag='开头。 self.matchCookie(r'^crawlprotecttag='), # 检查响应内容中的标题()是否包含'crawlprotect'。 self.matchContent(r'<title>crawlprotect'), # 检查响应内容中是否包含特定字符串,表示此站点受 crawlprotect 保护。 self.matchContent(r'this site is protected by crawlprotect') ] # 如果方案列表中的任何一个方案为真,则认为检测到了 WAF。 if any(i for i in schemes): return True else: return False