1. 缓慢攻击

缓慢的HTTP拒绝服务攻击是一种专门针对于Web的应用层拒绝服务攻击,攻击者操纵网络上的肉鸡,对目标Web服务器进行海量HTTP请求攻击,直到服务器带宽被打满,造成了拒绝服务。

慢速HTTP拒绝服务攻击经过不断的演变和发展,主要有三种攻击类型,分别是Slow headers、Slow body、Slow read。以Slow headers为例,Web应用在处理HTTP请求之前都要先接收完所有的HTTP头部,因为HTTP头部中包含了一些Web应用可能用到的重要的信息。攻击者利用这点,发起一个HTTP请求,一直不停的发送HTTP头部,消耗服务器的连接和内存资源。抓包数据可见,攻击客户端与服务器建立TCP连接后,每10秒才向服务器发送一个HTTP头部,而Web服务器在没接收到2个连续的 时,会认为客户端没有发送完头部,而持续的等等客户端发送数据。如果恶意攻击者客户端持续建立这样的连接,那么服务器上可用的连接将一点一点被占满,从而导致拒绝服务。这种攻击类型称为慢速HTTP拒绝服务攻击。

1.1. Nginx

  1. 通过调整$request_method,配置服务器接受http包的操作限制;

  2. 在保证业务不受影响的前提下,调整client_max_body_size, client_body_buffer_size, client_header_buffer_size,large_client_header_buffersclient_body_timeout, client_header_timeout的值,必要时可以适当的增加;

  3. 对于会话或者相同的ip地址,可以使用HttpLimitReqModule and HttpLimitZoneModule参数去限制请求量或者并发连接数;

  4. 根据CPU和负载的大小,来配置worker_processes 和 worker_connections的值,公式是:max_clients = worker_processes * worker_connections。

1.2. Nginx、Tengine、Openresty

配置示例
client_max_body_size: 2m
client_body_buffer_size

针对不同的Server其对慢速http拒绝服务攻击防范方法也不同,建议使用以下措施防范慢速http拒绝服务攻击:

1.3. WebSphere

  1. 限制 HTTP 数据的大小 在WebSphere Application Server 中进行如下设置:
    任何单个 HTTP 头的默认最大大小为 32768 字节。可以将它设置为不同的值。 HTTP 头的默认最大数量为 50。可以将它设置为不同的限制值。 另一种常见的 DOS 攻击是发送一个请求,这个请求会导致一个长期运行的 GET 请求。WebSphere Application Server Plug-in 中的 ServerIOTimeoutRetry 属性可限制任何请求的重试数量。这可以降低这种长期运行的请求的影响。 设置限制任何请求正文的最大大小。

  2. 设置keepalive参数 打开ibm http server安装目录,打开文件夹conf,打开文件httpd.conf,查找KeepAlive值,改ON为OFF,其默认为ON。 这个值说明是否保持客户与HTTP SERVER的连接,如果设置为ON,则请求数到达MaxKeepAliveRequests设定值时请求将排队,导致响应变慢。

1.4. Weblogic

  1. 在配置管理界面中的协议→一般信息下设置 完成消息超时时间小于200

  2. 在配置管理界面中的协议→HTTP下设置 POST 超时、持续时间、最大 POST 大小为安全值范围。

1.5. Apache

建议使用mod_reqtimeout和mod_qos两个模块相互配合来防护。

  1. mod_reqtimeout用于控制每个连接上请求发送的速率。配置例如:

    #请求头部分,设置超时时间初始为10秒,并在收到客户端发送的数据后,每接收到500字节数据就将超时时间延长1秒,但最长不超过40秒。可以防护slowloris型的慢速攻击。
    RequestReadTimeout header=10-40,minrate=500
    #请求正文部分,设置超时时间初始为10秒,并在收到客户端发送的数据后,每接收到500字节数据就将超时时间延长1秒,但最长不超过40秒。可以防护slow message body型的慢速攻击。
    RequestReadTimeout body=10-40,minrate=500

    需注意,对于HTTPS站点,需要把初始超时时间上调,比如调整到20秒。 示例:

    LoadModule reqtimeout_module modules/mod_reqtimeout.so
    <IfModule reqtimeout_module>
            RequestReadTimeout header=10-40,minrate=500 body=10-40,minrate=500
    </IfModule>
  2. mod_qos用于控制并发连接数。配置例如:

    # 当服务器并发连接数超过600时,关闭keepalive
    QS_SrvMaxConnClose 600
    # 限制每个源IP最大并发连接数为50
    QS_SrvMaxConnPerIP 50

    这两个数值可以根据服务器的性能调整。 更多关于qos_module配置参考: http://mod-qos.sourceforge.net/dos.html 示例:

    LoadModule qos_module modules/mod_qos.so
    <IfModule qos_module>
    QS_SrvMaxConnClose 600
    QS_SrvMaxConnPerIP 50
    </IfModule>

1.6. IHS服务器

请您先安装最新补丁包,然后启用mod_reqtimeout模块,在配置文件中加入: LoadModule reqtimeout_module modules/mod_reqtimeout.so 为mod_reqtimeout模块添加配置:

<IfModule mod_reqtimeout.c>
RequestReadTimeout header=10-40,MinRate=500 body=10-40,MinRate=500
</IfModule>

对于HTTPS站点,建议 header=20-40,MinRate=500 参见:http://www-01.ibm.com/support/docview.wss?uid=swg21652165

1.7. F5负载均衡修复建议

F5负载均衡设备有相应的防护模块,如无购买可参考附件中的详细配置过程。 关于F5的慢速攻击防护配置,请参考以下链接: https://support.f5.com/kb/en-us/solutions/public/10000/200/sol10260.html https://devcentral.f5.com/articles/mitigating-slow-http-post-ddos-attacks-with-irules-ndash-follow-up

1.8. IIS服务器

IIS可配置相关网站的Web.config如下: 1、WebLimits设置:

<configuration>
    <system.applicationHost>
        <webLimits connectionTimeout="00:00:30"
        headerWaitTimeout="00:00:10"
        dynamicIdleThreshold="150"
        minBytesPerSecond="512"
    />
    </system.applicationHost>
</configuration>

2、headerLimits设置:

<configuration>
 <system.webServer>
  <security>
   <requestFiltering>
    <requestLimits>
     <headerLimits>
     <add header="Content-type" sizeLimit="100" />
     </headerLimits>
    </requestLimits>
   </requestFiltering>
  </security>
 </system.webServer>
</configuration>

2. HTTP HEADER

2.1. Content-Security-Policy

HTTP 响应头Content-Security-Policy允许站点管理者控制用户代理能够为指定的页面加载哪些资源。除了少数例外情况,设置的政策主要涉及指定服务器的源和脚本结束点。 Content-Security-Policy响应头的缺失使得目标URL更易遭受跨站脚本攻击。

Nginx、Tengine、Openresty等配置示例
add_header Content-Security-Policy: "default-src 'self'" always;

2.2. X-Content-Type-Options

X-Content-Type-Options HTTP 消息头相当于一个提示标志,被服务器用来提示客户端一定要遵循在 Content-Type 首部中对 MIME 类型 的设定,而不能对其进行修改。这就禁用了客户端的 MIME 类型嗅探行为,换句话说,也就是意味着网站管理员确定自己的设置没有问题。 X-Content-Type-Options响应头的缺失使得目标URL更易遭受跨站脚本攻击。

Nginx、Tengine、Openresty等配置示例
add_header X-Frame-Options: nosniff always;

2.3. X-Frame-Options

点击劫持(ClickJacking)是一种视觉上的欺骗手段。攻击者使用一个透明的、不可见的iframe,覆盖在一个网页上,然后诱使用户在该网页上进行操作,此时用户将在不知情的情况下点击透明的iframe页面。通过调整iframe页面的位置,可以诱使用户恰好点击在iframe页面的一些功能性按钮上。 HTTP 响应头信息中的X-Frame-Options,可以指示浏览器是否应该加载一个 iframe 中的页面。如果服务器响应头信息中没有X-Frame-Options,则该网站存在ClickJacking攻击风险。网站可以通过设置 X-Frame-Options 阻止站点内的页面被其他页面嵌入从而防止点击劫持。

修改web服务器配置,添加X-Frame-Options响应头。赋值有如下三种
  1. DENY:不能被嵌入到任何iframe或者frame中。

  2. SAMEORIGIN:页面只能被本站页面嵌入到iframe或者frame中。

  3. ALLOW-FROM uri:只能被嵌入到指定域名的框架中。

Nginx、Tengine、Openresty等配置示例
add_header X-Frame-Options: SAMEORIGIN always;

2.4. X-XSS-Protection

HTTP X-XSS-Protection 响应头是 Internet Explorer,Chrome 和 Safari 的一个特性,当检测到跨站脚本攻击 (XSS)时,浏览器将停止加载页面。 X-XSS-Protection响应头的缺失使得目标URL更易遭受跨站脚本攻击。

Nginx、Tengine、Openresty等配置示例
add_header X-XSS-Protection: "1; mode=block" always;

2.5. Strict-Transport-Security

Web 服务器对于 HTTP 请求的响应头中缺少 Strict-Transport-Security,这将导致浏览器提供的安全特性失效。 当 Web 服务器的 HTTP 头中包含 Strict-Transport-Security 头时,浏览器将持续使用 HTTPS 来访问 Web 站点,可以用来对抗协议降级攻击和 Cookie 劫持攻击。 其可选的值有:: - max-age=SECONDS,表示本次命令在未来的生效时间; - includeSubDomains可以用来指定是否对子域名生效。

Nginx、Tengine、Openresty等配置示例
add_header  Strict-Transport-Security: max-age=31536000; includeSubDomains always;

2.6. Referrer-Policy

Web 服务器对于 HTTP 请求的响应头中缺少 Referer-Policy,这将导致浏览器提供的安全特性失效。 当用户在浏览器上点击一个链接时,会产生一个 HTTP 请求,用于获取新的页面内容,而在该请求的报头中,会包含一个 Referrer,用以指定该请求是从哪个页面跳转页来的,常被用于分析用户来源等信息。但是也成为了一个不安全的因素,所以就有了 Referer-Policy,用于过滤 Referrer 报头内容。 其可选的项有:: - no-referrer no-referrer-when-downgrade origin origin-when-cross-origin same-origin strict-origin strict-origin-when-cross-origin unsafe-url

Nginx、Tengine、Openresty等配置示例
add_header Referrer-Policy "origin-when-crossorigin" always;

2.7. X-Permitted-Cross-Domain-Policies

Web 服务器对于 HTTP 请求的响应头中缺少 X-Permitted-Cross-Domain-Policies,这将导致浏览器提供的安全特性失效。 当一些在线的 Web Flash 需要加载其他域的内容时,很多 Web 会通过设置一个 crossdomain.xml 文件的方式来控制其跨域方式。很有可能有些开发者并没有修改 crossdomain.xml 文件的权限,但是又有和跨域的 Flash 共享数据的需求,这时候可以通过设置 X-Permitted-Cross-Domain-Policies 头的方式来替代 crossdomain.xml 文件。 其可选的项有:: none master-only by-content-type by-ftp-filename all

Nginx、Tengine、Openresty等配置示例
add_header X-Permitted-Cross-Domain-Policies master-only always;

2.8. X-Download-Options

Web 服务器对于 HTTP 请求的响应头中缺少 X-Download-Options,这将导致浏览器提供的安全特性失效。

Nginx、Tengine、Openresty等配置示例
add_header X-Download-Options: noopen always;

3. 隐藏版本号

3.1. nginx

server_tokens off;