Nginx 基于客户端 IP 来开启/关闭认证
前些日子帮助公司在搭建了一个内部资源的导航页面,方便公司员工访问各种常用的系统。因为这个页面包含一些敏感信息,我们希望对其做认证,但仅当从外网访问的时候才开启,当从公司内网访问的时候,则无需输入账号密码。
按照这个需求研究了下 Nginx 配置,发现 satisfy
指令可以很好地解决这个问题。下面贴出来我们的配置:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
|
其中 satisfy
作用于所有的 access phase handler,参数值有两种:all
和 any
,分别代表所有规则都满足和任一规则满足。将其配置为 any
,并配合 auth_basic 和 access 模块就可以基于 IP 地址来开启/关闭认证。
以我们的规则为例,192.168.0.0/22
这个内网网段和 111.222.333.1
(虚构的)这个 IP 的 Client 是可以访问的,而其他用户则需要进行认证。