NGINX基于子请求结果的身份验证

介绍

NGINX和NGINX Plus可以通过外部服务器或服务验证每个对您网站的请求。为了执行身份验证,NGINX向验证子请求的外部服务器发出HTTP子请求。如果子请求返回2xx响应代码,则允许访问;如果子请求返回401或403,则拒绝访问。此类身份验证允许实现各种身份验证方案,例如多因素身份验证,或者允许实现LDAP或OAuth身份验证。

先决条件
  • NGINX Plus或NGINX开源版
  • 外部认证服务器或服务
配置NGINX和NGINX Plus
  1. 确保使用with-http_auth_request_module配置选项编译了NGINX开源。运行此命令并验证输出是否包括 --with-http_auth_request_module:
$ nginx -V 2>&1 | grep -- 'http_auth_request_module'
  1. 在需要请求身份验证的位置,指定auth_request指令,在该指令中指定将授权子请求转发到的内部位置:
location /private/ {
    auth_request /auth;
    #...
}

在这里,对于每个到 /private 的请求,都会向内部 /auth 位置发出一个子请求。

  1. 指定一个内部位置和此位置内的proxy_pass指令,该指令将把身份验证子请求代理到身份验证服务器或服务:
location = /auth {
    internal;
    proxy_pass http://auth-server;
    #...
}
  1. 由于身份验证子请求将丢弃请求体,因此需要将proxy-pass-request-body指令设置为off,并将Content-Length头设置为空字符串:
location = /auth {
    internal;
    proxy_pass              http://auth-server;
    proxy_pass_request_body off;
    proxy_set_header        Content-Length "";
    #...
}
  1. 使用带有proxy_set_header指令的参数传递完整的原始请求URI:
location = /auth {
    internal;
    proxy_pass              http://auth-server;
    proxy_pass_request_body off;
    proxy_set_header        Content-Length "";
    proxy_set_header        X-Original-URI $request_uri;
}
  1. 作为选择,您可以使用auth_request_set指令根据子请求的结果设置变量值:
location /private/ {
    auth_request        /auth;
    auth_request_set $auth_status $upstream_status;
}
完整的例子

本示例将前面的步骤总结为一个配置:

http {
    #...
    server {
    #...
        location /private/ {
            auth_request     /auth;
            auth_request_set $auth_status $upstream_status;
        }

        location = /auth {
            internal;
            proxy_pass              http://auth-server;
            proxy_pass_request_body off;
            proxy_set_header        Content-Length "";
            proxy_set_header        X-Original-URI $request_uri;
        }
    }
}
参考文档

https://docs.nginx.com/nginx/admin-guide/security-controls/configuring-subrequest-authentication/

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值