开发者社区> 科技小能手> 正文

nginx,apache的alias和认证功能

简介:
+关注继续查看

从年前电脑换成linux系统后就没写东西,最近有点懒,在这里讲述下nginx alias 功能,不是server alias .

首先看下看下apache 别名 怎么配置的:

<VirtualHost *:80>  

  DocumentRoot /www/hou.net/www   这是虚拟主机的根目录吧,但是phpMYadmin 不在这个目录下,想访问。

   ServerName  www.hou.net  

ServerAlias hou.net     

Alias /sdb "/www/public/phpMyAdmin/"   就需要 别名功能,:http://www.hou.com/sdb 这样就安全多了。

    <Directory "/www/public/phpMyAdmin/">    

    Options Indexes FollowSymLinks    

    AllowOverride None     

   Order allow,deny       

Allow from all   

</Directory>    

</VirtualHost>


 

一 .Apache认证

认证的类型:Basic

Digest摘要

认证方法:A、容器认证: ……

B、隐藏文件认证创建.htaccess文件

方法一、容器认证

A、 进入配置文件 vi /etc/httpd/conf/httpd.conf

B、 配置:大约在531行附近 配置如下:

AllowOverride None ##不允许通过隐藏认证,即通过容器认证

AuthType Basic ##认证类型为Basic

AuthName “ajian” ##认证名字为Ajian

AuthUserFile /var/www/passwd/pass ##pass 为认证密码文件,指定密码文件存放的位置。

Require valid-user ##有效用户(注意大小写,因为Word的原因有些大小写有变化)

C、 创建目录 mkdir -p /var/www/passwd

进入目录 cd /var/www/passwd

D、创建Apache用户 htpasswd -c pass ajian ##pass 为密码文件Ajian为用户

更改 把Pass文件的使用权给Apache: chown apache.apache pass

附:再在Pass文件中添加一个用户:htpasswd pass tt ##添加一个TT的用户到Pass文件中

E、重启服务并测试

方法二、通过隐藏认证

和上面差不多 不过配置不一样

Httpd主配置文件

AllowOverride AuthConfig

创建隐藏文件并放到要通过认证的目录

Eg: vi /var/www/html/mrtg

AuthType Basic

AuthName “Ajian”

AuthUserFile /var/www/passwd/pass

Require valid-user

 下面是例子

 

 

二、Nginx 登录认证

nginx 的 http auth basic 的密码是用 crypt(3) 加密的。用 apache 的 htpasswd 可以生成密码文件。

没有 apache 自行安装。我安装的是 apache2,/usr/local/apach2。

  1. cd /usr/local/nginx/conf   
  2. /usr/local/apache2/bin/htpasswd -c -d pass_file user_name   
  3. #回车输入密码,-c 表示生成文件,-d 是以 crypt 加密。   
  4. vi nginx.conf  

在 nginx.conf 文件中加入授权声明。这里要注意 nginx 0.6.7 开始,auth_basic_user_file 的相对目录是 nginx_home/conf,以前版本的相对目录是 nginx_home。

server {
    listen       80;
    server_name tuan.xywy.com;
    root  /www/tuangou;
    index index.html index.htm index.php;
    autoindex on;  
 
    auth_basic "input you user name and  password";
    auth_basic_user_file htpasswd.file;
 
    location ~ .php$ {
        fastcgi_pass  127.0.0.1:9000;
        fastcgi_index index.php;
       fastcgi_param SCRIPT_FILENAME /www/tuangou$fastcgi_script_name;
        include fastcgi_params;
    }
        error_page   404   /404.php;
        error_page   403   /404.php;

    access_log /logs/tuan_access.log main;
}

针对目录的认证,在一个单独的location中,并且在该location中嵌套一个解释php的location,否则php文件不会执行并且会被下载。auth_basic在嵌套的location之后。

server {
    listen       80;
    server_name tuan.xywy.com;
    root  /www/tuangou;
    index index.html index.htm index.php;
   autoindex on;  
    location ~ ^/admin/.* {
        location ~ \.php$ {
           fastcgi_pass  127.0.0.1:9000;
           fastcgi_index index.php;
           fastcgi_param SCRIPT_FILENAME /www/tuangou$fastcgi_script_name;
           include fastcgi_params;
        }
           root /www/tuangou/ ;
        auth_basic "auth";
        auth_basic_user_file htpasswd.file;
    }
 
    location ~ .php$ {
        fastcgi_pass  127.0.0.1:9000;
        fastcgi_index index.php;
        include fastcgi_params;
    }
 
    access_log /logs/tuan_access.log main;
}

 

 

三.nginx alias功能配置自动列目录

    server {

        listen      www.hou.com:88;

        server_name  www.hou.com;

        autoindex on;                    //开启列目录功能。       

# charset gbk;
          location /club  {                                       访问的名字http://www.hou.com:88/club
      alias /www/clublog/club.xywy.com/;      这是服务器上存放日志的地方
    }                                                                         这段意思 访问www.hou.com:88/club 就看到club目录的东东了。  
        location /{
       root    /www/access;    
这段location 也可以没有 www.hou.com:88 出来的是默认nxing 页面  
    #    index  index.html index.htm index.php;
     }
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        } 
    }

上面nginx配置意思就是: 访问http://hou.xywy.com/:88认证进去是默认访问服务器上/www/access/里面的目录,认证进去后url=http://hou.xywy.com:88/club 就出来 /www/clublog/club.xywy.com/ 里面的目录的内容了。,可能很绕,仔细分析就好了。

root 和 alias 的区别。
最基本的区别:alias指定的目录是准确的,root是指定目录的上级目录,并且该上级目录要含有location指定名称的同名目录。另外,根据前文所述,使用alias标签的目录块中不能使用rewrite的break。

这样在看这段就很清晰了,

location /abc/ {
alias /home/html/abc/;
}

在这段配置下,http://test/abc/a.html就指定的是/home/html/abc/a.html。这段配置亦可改成

location /abc/ {
root /home/html/;
}

这样,nginx就会去找/home/html/目录下的abc目录了,得到的结果是相同的。

但是,如果我把alias的配置改成:

location /abc/ {
alias /home/html/def/;
}

那么nginx将会从/home/html/def/取数据,这段配置还不能直接使用root配置,如果非要配置,只有在/home/html/下建立一个 def->abc的软link(快捷方式)了。

一般情况下,在location /中配置root,在location /other中配置alias是一个好习惯。

至于alias和root的区别,我估计还没有说完全,如果在配置时发现奇异问题,不妨把这两者换换试试。

刚开始我也搞来高去搞了很久包括认证单独一个目录 CGI 问题,希望大家成功。出现问题可以向我咨询大家共同进步!



本文转自 houzaicunsky 51CTO博客,原文链接:http://blog.51cto.com/hzcsky/491138

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

相关文章
Apache Flume-高阶-容错(故障转移)功能|学习笔记
快速学习 Apache Flume-高阶-容错(故障转移)功能
59 0
Apache Flume-高阶-负载均衡功能|学习笔记
快速学习 Apache Flume-高阶-负载均衡功能
60 0
Nginx:root与alias的区别
Nginx:root与alias的区别
65 0
Apache Superset 1.2.0教程 (三)—— 图表功能详解
通过之前章节的学习,我们已经成功地安装了superset,并且连接mysql数据库,可视化了王者英雄的数据。使用的是最简单Table类型的图表,但是superset还支持非常多的图表类型。 本文我们将对各种图表类型进行逐一的演示,文章较长。
401 0
nginx中root和alias的区别
nginx中root和alias的区别
95 0
Apache Doris 查询分析功能使用
Doris提供了一个图形化的命令帮助用户方便分析一个具体的查询或者导入操作,在使用过程中的性能问题,本文主要介绍如何使用改功能.
853 0
Nginx:root与alias的区别
Nginx:root与alias的区别
63 0
深度集成 Flink: Apache Iceberg 0.11.0 最新功能解读
Apache Flink 和 Apache Iceberg 在共同打造流批一体的数据湖架构上开启了新的篇章。
2688 0
NGINX虚拟目录alias和root目录
  假设nginx配置的域名是www.kazihuo.com,现有静态资源/home/www/oye目录需要通过nginx访问。 1、在nginx.conf中到处第二行添加内容‘include /usr/local/nginx/conf/conf.
1437 0
+关注
科技小能手
文章
问答
视频
文章排行榜
最热
最新
相关电子书
更多
CentOS Nginx PHP JAVA多语言镜像使用手册
立即下载
低代码开发师(初级)实战教程
立即下载
阿里巴巴DevOps 最佳实践手册
立即下载
相关镜像