【云安全最佳实践】T-Sec Web 应用防火墙实践接入
什么是 Web 应用防火墙
腾讯云 Web 应用防火墙(Web Application Firewall,WAF)是一款基于 AI 的一站式 Web 业务运营风险防护方案。通过 AI+规则双引擎识别恶意流量,保护网站安全,提高 Web 站点的安全性和可靠性。通过 BOT 行为分析,防御恶意访问行为,保护网站核心业务安全和数据安全。
腾讯云 WAF 提供两种类型的云上 WAF,SaaS 型 WAF 和负载均衡型 WAF,两种 WAF 提供的安全防护能力基本相同,接入方式不同。
- SaaS 型 WAF 通过 DNS 解析,将域名解析到 WAF 集群提供的 CNAME 地址上,通过 WAF 配置源站服务器 IP,实现域名恶意流量清洗和过滤,将正常流量回源到源站,保护网站安全。
- 负载均衡型 WAF 通过和腾讯云负载均衡集群进行联动,将负载均衡的 HTTP/HTTPS 流量镜像到 WAF 集群,WAF 进行旁路威胁检测和清洗,将用户请求的可信状态同步到负载均衡集群进行威胁拦截或放行,实现网站安全防护。
腾讯云 WAF 可以有效防御 SQL 注入、XSS 跨站脚本、木马上传、非授权访问等 OWASP 攻击。此外还可以有效过滤 CC 攻击、提供 0day 漏洞补丁、防止网页篡改等,通过多种手段全方位保护网站的系统以及业务安全
相关文档
下面T-Sec Web 应用防火墙简称waf
那么我们就用腾讯云saas防火墙演示
多种接入防护方式 AI+规则双引擎防护 BOT 流量管理 智能 CC 防护 IPv6 安全防护
购买waf需要考虑以下原因
1.服务器在什么地方?
2.服务区域在哪里?
3.网站是否备案并且接入腾讯云?(境外不需要,境内强制备案并且接入腾讯云)
4.网站业务大小
5.我需要要接入多少域名
6.网站访问量
查看WAF 套餐与版本说明 选择合适的套餐为网站保驾护航
支持的地区:腾讯云目前的对外机房的地区
那么这次就用香港waf来说一下吧
那么我就用香港的轻量应用服务器作为服务器源站
生成token
登录服务器终端
执行刚刚的安装命令
执行刚刚的安装命令。
显示OK就安装成功了
以dnspod举例执行签发SSL命令
export DP_Id="youdnspodID"
export DP_Key="youdnspodkey"
acme.sh --issue \\
--dns dns_dp \\
-d \\*.youdomain \\
-d youdomain \\
--days 150 \\
--server https://acme.hi.cn/directory
其他验证方法请访问
https://www1.hi.cn/docs/category/%E5%9F%9F%E5%90%8D%E9%AA%8C%E8%AF%81 官方文档查看
等待1-2分钟即可签发
签发成功 推荐HI.cn是因为 他们家泛解析是180天 是Sectigo的根 兼容性也比较强 还支持的windows7和windows xp的正常访问
如果有其他的 acme.sh 需要删除的哦 否则导致SSL无法签发
开始接入接入
场景1:用户>WAF>源站
配置SSL和ssl跳转 SSL跳转目前是302
WAF添加域名设置
waf支持泛解析哦,目前大部分ssl的泛解析就是90天的 HI.cn 是180天 可以在一定程度上减少频繁更换SSL的周期哦
设置完成点击高级配置
这就接入好了
可以去myssl.com查看 你的网站
测试一下这个配置
看到了不少人接入WAF如果设置之后提示
需要重新配置一下TLS,如需问题依旧麻烦则需要提交工单,目前给的配置是完全没有问题了啦,需要腾讯云后端同学帮忙查看
场景二:用户>CDN>WAF>源站
接入参考场景一首先完成域名在WAF的接入,下面说一下接入CDN的教程
在waf控制台开启这个才可以正常接入并且让waf获取真实访客IP
这个推荐使用腾讯云CDN
- 场景二中,需要在 WAF 添加域名 时,选择代理情况为“是”,选择代理接入后,可能存在客户端 IP 被伪造的风险。如果您使用腾讯云 CDN,不存在客户端 IP 被伪造的风险,腾讯云 CDN 会对 X-Forwarded-For 信息进重置,只填写 CDN 获取的客户端 IP。(如果使用代理接入,攻击者需要在能直接对 WAF VIP 地址进行请求的情况下才会产生影响,代理接入时用户无法探测到 WAF VIP 地址,请避免代理接入时 WAF VIP 地址泄露)。
场景二的完整加速链接如下
打开腾讯云CDN控制台接入域名
根据业务需求与预期设置缓存
复制给你的CNAME !!(场景二不需要接入WAF给你的CNAME接入CDN给你的 CDN回源WAF,WAF回源服务器,如果使用场景2的话如果保留了waf的解析记录可能网站部分访客无法获得CDN加速效果)
解析域名
配置cdn侧 SSL和高级设置
cc就有waf来处理就好了
高级设置
访问查看
这样有了防护和加速效果
说明:WAF≠CDN 那么 CDN≠WAF
WAF主要靠转发就相当于反向代理,WAF侧一般情况下是不缓存你的东西的,那么就需要每次去源站获取资源
CDN主要靠缓存来进行网站加速 那么可以减轻源站的压力 同时CDN也可以继承WAF的防护能力,何乐不为
注意!!源站需要设置
WAF 通过反向代理的方式实现网站安全防护,用户访问 WAF 防护的域名时,会在 HTTP 头部字段中添加一条 X-Forwarded-For 记录,用于记录用户真实 IP,其记录格式为X-Forwarded-For:用户 IP。如果用户访问域名存在多级代理,WAF 将记录靠近 WAF 上一条的代理服务器 IP。例如:
场景一:用户>WAF>源站,X-Forwarded-For 记录为:X-Forwarded-For:用户真实 IP。
场景二:用户>CDN > WAF>源站,X-Forwarded-For 记录为:X-Forwarded-For:用户真实 IP,X-Forwarded-For:CDN 回源地址。
不建议使用场景二哦 可能获取访客ip可能有点问题
具体数字参考 https://cloud.tencent.com/document/product/627/42441
否则可能获取到WAF的ip导致源站日志可能出现不准确的问题
下面就开始进阶配置啦
进阶配置(场景一、二通用)
1.接入域名的高级设置
根据自己需求设置
waf目前支持的加密套件
加密套件
一般情况下选择通用 有关于安全,支付什么的敏感信息用安全
如果有自定义需求 勾选一下加红的就好
推荐设置加密套件
比如说我没设置TLS1.0那么TLS1.0访问就会
WAF拦截页面
PCI安全标准委员会官方发表博文将于2018年6月30号(最晚),也就是本月月底禁用早期SSL/TLS,并实施更安全的加密协议(TLS v1.1或更高版本,强烈建议使用TLS v1.2)以满足PCI数据安全标准的要求,从而保护支付数据。
也就是说支持TLS v1.0或更早的加密协议将会判定为不合规
那么支持TLS1.0就会
2.waf规则设置
waf规则默认比较严格 可能出现误拦截
那么我们这样设置 打开waf基础安全
防护等级 正常或者宽松
cc防护根据业务量决定
然后打开黑白名单 加白网站后台防止WAF拦截后台管理员操作行为
设置白名单
3.设置安全组与加白IP (场景一,二)
然后去服务器安全组
直接复制 导入到黑白名单的IP白名单
可选(加白腾讯CDN头部)
x-tencent-ua:Qcloud
此外WAF VIP 地址免费和正常服务器防御一样 需要购买DDOS高防包哦!
测试waf 抗压效果
此外,可以使用云压测服务进行测试
点击链接访问
项目列表 - 云压测 - 控制台 (tencent.com)
内测期间免费50ua 和400rps
与自己的需求配置,然后点击执行
可以看出来,在这么大的并发前提下,还是有较好的延迟。
请求失败才占0.01%。由于我这边测试是境外节点。
测试了将近20分钟
一般来说都是能扛住的,大家可以放心使用。可以看看日志是否拦截了。测试的时候建议加白IP。云压测IP具体已waf日志显示为主。
看了一下,应该是波动导致的 问题不大。
接入的话也可接入的话也可以测试测试自己的配置怎么样,能不能扛住一定并发。会不会对原产生一定影响。 此外可以自定义hosts,可以和waf与源站,之间的结果对比一下,你会发现好了一大截。