模块 ngx_http_secure_link_module

指令
     secure_link
     secure_link_md5
     secure_link_secret
嵌入式变量

ngx_http_secure_link_module 模块 (0.7.18) 用于检查请求链接的真实性,保护资源免遭未经授权的访问,并限制链接的生存期。

通过将请求中传递的校验和值与为该请求计算的值进行比较来验证请求链接的真实性。如果链接的生存期有限并且时间已到期,则该链接将被视为已过期。这些检查的状态在 $secure_link 变量中提供。

该模块提供两种备用操作模式。第一种模式由 secure_link_secret 指令启用,用于检查请求链接的真实性以及保护资源免遭未经授权的访问。第二种模式 (0.8.50) 由 secure_linksecure_link_md5 指令启用,还用于限制链接的生存期。

此模块默认情况下不构建,应使用 --with-http_secure_link_module 配置参数启用它。

指令

语法 secure_link 表达式;
默认值
上下文 httpserverlocation

定义一个字符串,其中包含变量,从中将提取链接的校验和值和生存期。

表达式 中使用的变量通常与请求关联;请参见下面的 示例

从字符串中提取的校验和值与由 secure_link_md5 指令定义的表达式的 MD5 哈希值进行比较。如果校验和不同,则 $secure_link 变量将设置为空字符串。如果校验和相同,则检查链接的生存期。如果链接的生存期有限并且时间已到期,则 $secure_link 变量将设置为 “0”。否则,将其设置为 “1”。请求中传递的 MD5 哈希值以 base64url 编码。

如果链接的有效期有限,则过期时间以自纪元(1970 年 1 月 1 日星期四 00:00:00 GMT)起的秒数为单位进行设置。该值在 MD5 哈希值后面的表达式中指定,并用逗号分隔。请求中传递的过期时间可通过 $secure_link_expires 变量在 secure_link_md5 指令中使用。如果未指定过期时间,则链接的有效期为无限期。

语法 secure_link_md5 expression;
默认值
上下文 httpserverlocation

定义一个表达式,将计算其 MD5 哈希值并与请求中传递的值进行比较。

该表达式应包含链接(资源)的安全部分和一个秘密成分。如果链接的有效期有限,则该表达式还应包含 $secure_link_expires

为防止未经授权的访问,该表达式可能包含有关客户端的一些信息,例如其地址和浏览器版本。

示例

location /s/ {
    secure_link $arg_md5,$arg_expires;
    secure_link_md5 "$secure_link_expires$uri$remote_addr secret";

    if ($secure_link = "") {
        return 403;
    }

    if ($secure_link = "0") {
        return 410;
    }

    ...
}

/s/link?md5=_e4Nc3iduzkWRm01TBBNYw&expires=2147483647” 链接限制了 IP 地址为 127.0.0.1 的客户端对“/s/link”的访问。该链接的有效期也限制到 2038 年 1 月 19 日(格林尼治时间)。

在 UNIX 上,md5 请求参数值可获取为

echo -n '2147483647/s/link127.0.0.1 secret' | \
    openssl md5 -binary | openssl base64 | tr +/ -_ | tr -d =

语法 secure_link_secret word;
默认值
上下文 位置

定义用于检查请求链接真实性的秘密 word

请求链接的完整 URI 如下所示

/prefix/hash/link

其中 hash 是为链接和秘密词的连接计算的 MD5 哈希的十六进制表示,而 prefix 是不带斜杠的任意字符串。

如果请求的链接通过了真实性检查,则 $secure_link 变量将设置为从请求 URI 中提取的链接。否则,$secure_link 变量将设置为一个空字符串。

示例

location /p/ {
    secure_link_secret secret;

    if ($secure_link = "") {
        return 403;
    }

    rewrite ^ /secure/$secure_link;
}

location /secure/ {
    internal;
}

对“/p/5e814704a28d9bc1914ff19fa0c4a00a/link”的请求将在内部重定向到“/secure/link”。

在 UNIX 上,此示例的哈希值可获取为

echo -n 'linksecret' | openssl md5 -hex

嵌入变量

链接检查的状态。具体值取决于所选的操作模式。
请求中传递的链接的有效期;仅用于 secure_link_md5 指令。