Nginx里的location以及如何用户认证-阿里云开发者社区

开发者社区> 开发与运维> 正文
登录阅读全文

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

简介:

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


location的定位

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

wKioL1crQguy_1juAAA8NJOsgQU939.png

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

wKioL1crREHhcIMSAAAsxhhJ04g813.png

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

wKioL1crRWTTNVKhAAA0tSEb49s180.png

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

wKioL1crSPawLcNCAAAyzau-l_0175.png

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


nginx如何用户验证

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


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

     

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

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


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

1
2
3
# printf "chris:$(openssl passwd -crypt 123456)\n" >>conf/htpasswd
# cat conf/htpasswd 
chris:xyJkVhXGAZ8tM        <----这个就是账号密码,注意!真实的密码是123456

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



 本文转自 苏幕遮618 51CTO博客,原文链接:http://blog.51cto.com/chenx1242/1770572



版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享: