在使用nginx转发的时候,要进行一次用户身份的确认。
1)通过htpasswd命令生成用户名及对应密码数据库文件。
[root@bgs-5p173-wangwenting ~]# htpasswd -c /usr/local/nginx/passwd.db wyl //创建认证信息,wyl 为认证用户名 New password: ******* //输入认证密码 Re-type new password: ******** //再次输入认证密码 Adding password for user wyl [root@bgs-5p173-wangwenting ~]# chmod 755 /usr/local/nginx/passwd.db //修改网站认证数据库权限 [root@bgs-5p173-wangwenting ~]# chown root:root /usr/local/nginx/passwd.db //修改网站认证数据库属主和属组 [root@bgs-5p173-wangwenting ~]# cat /usr/local/nginx/passwd.db //可以看到通过htpasswd生成的密码为加密格式 wyl:r5IXRXWSmlBk6 |
2)编辑虚拟主机配置文件。
[root@bgs-5p173-wangwenting ~]# vim /usr/local/nginx/conf/nginx.conf //主配置文件中http字段中添加以下语句 server { listen 1234; server_name xx.xx.xx.104; auth_basic "s1"; #虚拟主机认证命名 auth_basic_user_file /usr/local/nginx/passwd.db; #虚拟主机用户名密码认证数据库 location /{ proxy_pass http://xx.xx.xx.xxx:5678; } } |
3)重启nginx
[root@bgs-5p173-wangwenting nginx]# ./nginx -s reload |