Nginx里的location以及如何用户认证

Nginx玩的就是“页面输出”,把新闻的页面放到新闻的文件夹里,把体育的页面放到体育的文件夹里,把动漫的页面放到动漫的文件夹里,然后搭配好各种正则搜寻,这样用户在浏览器的地址栏里输入对应的地址,服务器就回到相应的文件夹里去把网页呈现出来。


location的定位

服务器里的nginx.conf配置如图:

Nginx里的location以及如何用户认证_第1张图片

这个域名的server_name是localhost。location /里的/指的是 /usr/local/nginx/html 这个目录,此时,在/usr/local/nginx/html下建立一个叫welcome.html的文件,里面的内容是:“welcome to ChrisChan's server"。


然后#nginx -t,检查一下配置文件,都OK之后,就#nginx -s reload。

使用浏览器打开localhost可以看一下效果。

Nginx里的location以及如何用户认证_第2张图片

但是后面我还设置了一个二阶网页,/nba,虽然它的root也是/usr/local/nginx/html,但是这个index.html却不可以设置在/usr/local/nginx/html,而是要设置到/usr/local/nginx/html/nba里。于是在/usr/local/nginx/html/nba这个文件夹里,#echo "steven curry is MVP in 2016!" > index.html,同样重新检查nginx的配置文件语法然后重启,在浏览器看一下效果。

Nginx里的location以及如何用户认证_第3张图片

这里需要账号密码,在配置文件里我们已经看到了,账号密码都被记录在/usr/local/nginx/conf/passwd这个文件夹里,这样防止陌生人来访问这个网页。这个密码是可以被cookie记录的,而且上面的提示不可以是中文。

Nginx里的location以及如何用户认证_第4张图片

【总结】可以看出在浏览器地址栏里localhost/是指nginx.conf配置的root一大串地址,而localhost/nba里的文件对应是root/nba文件夹里的。


nginx如何用户验证

nginx用户验证有很多方法,http://dreamfire.blog.51cto.com/418026/1141385/这个文章就说明了一个方法,但是有一个方法比这个简单的多,使用ngx_http_auth_basic_module模块。


在nginx.conf里对应的网页写上

     

   location /                     #这里可以是任何后缀或者不加后缀
        {
                auth_basic "ABC";   #“ABC就是用户登录的提示
                auth_basic_user_file /usr/local/nginx/conf/passwd;    #这里是密码文件的路径 
                autoindex on
        }

备注:一定要注意auth_basic_user_file路径,否则会不厌其烦的出现403。


然后把配置文件保存退出,下面就是生成passwd这个密码文件:

# printf "chris:$(openssl passwd -crypt 123456)\n" >>conf/htpasswd
# cat conf/htpasswd 
chris:xyJkVhXGAZ8tM        <----这个就是账号密码

 然后#nginx -s reload,查看一下效果即可。如果用户认证失败,就会401 authorization required,这个密码是会被cookie记录的。




你可能感兴趣的:(nginx,location,用户认证)