码迷,mamicode.com
首页 > 其他好文 > 详细

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

时间:2016-05-06 02:24:50      阅读:306      评论:0      收藏:0      [点我收藏+]

标签:nginx   用户认证   location   配置   

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


location的定位

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

技术分享

这个域名的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可以看一下效果。

技术分享

但是后面我还设置了一个二阶网页,/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的配置文件语法然后重启,在浏览器看一下效果。

技术分享

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

技术分享

【总结】可以看出在浏览器地址栏里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记录的。




本文出自 “生活就是等待戈多” 博客,请务必保留此出处http://chenx1242.blog.51cto.com/10430133/1770572

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

标签:nginx   用户认证   location   配置   

原文地址:http://chenx1242.blog.51cto.com/10430133/1770572

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!