更新时间:2024-10-10 GMT+08:00
API网关专享版对接Web应用防火墙 WAF
企业为了保护APIG及后端服务器免受恶意攻击,可在APIG和外部网络之间部署WAF。
图1 后端服务器访问原理
方案一(推荐):WAF侧注册对外访问域名并配置证书,通过APIG实例的分组调试域名访问后端服务
推荐原因:API分组通过域名方式对外提供服务,具备更强的可扩展性。
- 在APIG实例中,新建API分组,并记录域名,将API添加在新建的分组中。
- 登录APIG控制台,在左侧导航栏中选择“API管理 > API分组”。
- 单击“创建分组 > 直接创建”,填写分组名称完成创建。
- 单击已创建分组名称,进入分组详情。
- 在“分组信息”页签中,查看调试域名并记录。该调试域名唯一且不可修改,每天最多可以访问1000次。
- 在“API运行”页签中,单击“创建API > 创建API”,即可添加API。
- 在WAF侧添加防护域名。进入WAF控制台,单击“网站设置 > 添加防护网站”,即可配置防护域名。配置“源站地址”时,需要填写API分组的域名,并添加证书。添加域名后,还需执行放行回源IP、本地验证、修改域名DNS解析设置。详细操作步骤请参考网站接入WAF(云模式)。
客户从公网客户端访问WAF时,使用的是WAF对外访问域名,WAF转发给APIG时同样使用该对外访问域名,APIG收到访问该域名的请求无次数限制。
- 在APIG实例中,为API分组绑定已创建的防护域名。
- 进入APIG控制台,在左侧导航栏中选择“API管理 > API分组”。
- 单击已创建的分组名称。
- 在“分组信息”页签中的“域名管理”区域,单击“绑定独立域名”。
- 在弹窗中添加已创建的防护域名即可。
- 在APIG实例中,将“real_ip_from_xff”开关打开,并设置参数运行值为“1”。
- 在APIG控制台的左侧导航栏中,选择“实例管理”。
- 在“配置参数”页签中,设置“real_ip_from_xff”参数。
方案二(备选):使用DEFAULT分组实现转发功能,WAF侧通过IP访问后端服务
- 在APIG实例中,查看入口地址。通过IP调用访问APIG实例,无访问次数限制。
- 登录APIG控制台,在左侧导航栏中选择“实例管理”。
- 单击实例名称或“查看控制台”。
- 在“基础信息”页签中,查看入口地址。
- 虚拟私有云访问地址为VPC内网地址。
- 弹性IP地址为公网地址。
- 在DEFAULT分组中添加API。
- 在APIG控制台的左侧导航栏中,选择“API管理 > API分组”。
- 单击“DEFAULT”分组名称。
- 单击“创建API > 创建API”,即可添加API。
- 在WAF侧添加防护域名。进入WAF控制台,单击“网站设置 > 添加防护网站”,即可配置防护域名。配置“源站地址”为API网关实例的入口地址,并添加证书。添加域名后,还需执行放行回源IP、本地验证、修改域名DNS解析设置。详细操作步骤请参考网站接入WAF(云模式)。
- 如果WAF与APIG在同一VPC下,“源站地址”可以填写私网地址。
- 如果APIG绑定弹性IP,“源站地址”可以填写公网地址。
- 在APIG实例中,为DEFAULT分组绑定已创建的防护域名。
- 在APIG控制台的左侧导航栏中,选择“API管理 > API分组”。
- 单击“DEFAULT”分组名称。
- 在“分组信息”页签中的“域名管理”区域,单击“绑定独立域名”。
- 在弹窗中添加已创建的防护域名。
- 在APIG实例中,将“real_ip_from_xff”开关打开,并设置参数运行值为“1”。
- 在APIG控制台的左侧导航栏中,选择“实例管理”。
- 在“配置参数”页签中,设置“real_ip_from_xff”参数。