返回介绍

介绍

其他

How-To

开发

模块参考

ngx_http_referer_module

发布于 2024-08-13 23:46:27 字数 7294 浏览 0 评论 0 收藏 0

ngx_http_referer_module 模块用于阻止 Referer 头字段为无效值的请求访问站点。需记住的是,使用适当的 Referer 字段值来伪造请求非常容易,因此本模块的预期目的不是要彻底阻止此类请求,而是阻止常规浏览器发送的大量流量请求。还应该考虑到,即使是有效请求,常规浏览器也可能不发送 Referer 字段。

示例配置

valid_referers none blocked server_names
         *.example.com example.* www.example.org/galleries/
         ~\.google\.;

if ($invalid_referer) {
  return 403;
}

指令

referer_hash_bucket_size

-说明
语法referer_hash_bucket_size size;
默认referer_hash_bucket_size 64;
上下文server、location

设置有效引用哈希表的桶大小。设置哈希表的详细信息在单独的文档中提供。

referer_hash_max_size

-说明
语法referer_hash_max_size size;
默认referer_hash_max_size 2048;
上下文server、location
提示该指令在 1.0.5 版本中出现

设置有效引用哈希表的最大 size。设置哈希表的详细信息在单独的文档中提供。

valid_referers

-说明
语法valid_referers none | blocked | server_names | string ...;
默认——
上下文server、location

指定 Referer 请求头字段值将导致内嵌的 $invalid_referer 变量设置为空字符串。否则,变量将为 1。匹配搜索不区分大小写。

参数说明如下:

  • none

    请求头中缺少 Referer 字段

  • blocked

    Referer 字段出现在请求头中,但其值已被防火墙或代理服务器删除,这些值为不以 http://https:// 开头的字符串

  • server_names

    Referer 请求头字段包含一个服务器名称

  • 任意字符串

    定义一个服务器名称和一个可选的 URI 前缀。服务器名称的开头或结尾可以包含*。在检查期间,Referer 字段中的服务器端口被忽略

  • 正则表达式

    第一个符号应为 。要注意的是,表达式只与 http://https:// 之后的文本匹配。

示例:

valid_referers none blocked server_names
         *.example.com example.* www.example.org/galleries/
         ~\.google\.;

内嵌变量

  • $invalid_referer

    如果 Referer 请求头字段的值有效,则为空字符串,否则为 1。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据
    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文