Nginx 启用 HTTP Basic Auth

2018-11-23 11:14:23 5146

ngx_http_auth_basic_module 模块可以实现访问者输入正确用户名和密码才允许访问指定目录内容。比如,可以实现 VPS 上放置的探针,只能输入用户名和密码后才能访问。


这样就不需要用下面的笨办法来阻止访客访问探针文件。


生成用户认证文件

echo "username:$(openssl passwd -crypt 'password')" >> /home/.htpasswd

其中,username 为用户名,password 为密码,/home/.htpasswd 为用户认证文件路径。


注意:密码长度最大为8位。


修改 Nginx 配置文件

location ^~ /test/ {
location ~ [^/]\.php(/|$)
{
try_files $uri =404;
fastcgi_pass  unix:/tmp/php-cgi.sock;
fastcgi_index index.php;
include fastcgi.conf;
}
auth_basic "Authorized users only";
auth_basic_user_file /home/.htpasswd;
}

以上为参考配置,请根据实际修改。


修改完配置,reload 一下 Nginx:


nginx -s reload

如无意外,就成功了。


提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: