NGINX:如何从URI中提取一些值并在auth_basic_user_file中使用它?

时间:2014-10-20 09:52:27

标签: nginx passwords protection

我为不同的客户提供了几个下载文件夹。每个文件夹必须使用自己的.htaccess文件进行密码保护。

为了简化我的nginx配置,我有以下问题:

如何从URI中提取客户名称(“customerA”)并在auth_basic_user_file中使用它?

这是我现在正在使用的配置:

server {
    root /usr/share/nginx/www;

    server_name localhost;

    autoindex on;

    location /build/customerA {
            index build.json;
            auth_basic "CustomerA Access Only!";
            auth_basic_user_file /usr/share/nginx/www/build/customerA/.htpasswd;
    }

    location /build/customerB {
            index build.json;
            auth_basic "CustomerB Access Only!";
            auth_basic_user_file /usr/share/nginx/www/build/customerB/.htpasswd;
    }
}

谢谢, 塞巴斯蒂安

1 个答案:

答案 0 :(得分:2)

如果未找到auth_basic_user_file,则nginx会故障转移到403(在1.7.5版本中测试)。所以你可以试试下面的正则表达式位置。缺点是你需要关注它在配置中相对于其他正则表达位置的位置,因为只匹配第一个:

location ~ ^/build/(?<customer>[^/]+) {
    index build.json;
    auth_basic "$customer Access Only!";
    auth_basic_user_file /usr/share/nginx/www/build/$customer/.htpasswd;
}

要避免这种情况,请考虑使用前缀位置包装正则表达式位置。然后它可以出现在您的配置中的任何位置,它将更加优雅地扩展:

location /build/ {
    location ~ ^/build/(?<customer>[^/]+) {
        index build.json;
        auth_basic "$customer Access Only!";
        auth_basic_user_file /usr/share/nginx/www/build/$customer/.htpasswd;
    }
}

或者将正则表达式放在服务器节之外的map指令中:

map $uri $no_customer {
    default 1;
    ~^/build/(?<customer>[^/]+) 0;
}

然后使用以下前缀位置:

location /build/ {
    if ($no_customer) { # optionally forbid if no customer specified
        return 403;
    }
    index build.json;
    auth_basic "$customer Access Only!";
    auth_basic_user_file /usr/share/nginx/www/build/$customer/.htpasswd;
}
相关问题