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。
- cd /usr/local/nginx/conf
- /usr/local/apache2/bin/htpasswd -c -d pass_file user_name
-
#回車輸入密碼,-c 表示生成檔案,-d 是以 crypt 加密。
- 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;
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;
location ~ ^/admin/.* {
location ~ .php$ {
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi_params;
}
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
相關文章
- Nginx(alias 和 root的區別)Nginx
- Nginx中root和alias的區別Nginx
- nginx root 和 alias 配置區別Nginx
- Nginx 的root和alias區別講解Nginx
- Apache和 nginxApacheNginx
- nginx和apache的區別NginxApache
- LNMP—Nginx的使用者認證LNMPNginx
- Nginx 新增 Auth Basic 認證Nginx
- nginx面試題-nginx和apache的區別Nginx面試題Apache
- Nginx虛擬目錄alias和root目錄Nginx
- nginx配置 —— root與alias的區別Nginx
- 【原創】Apache HTTP Server認證初探ApacheHTTPServer
- Linux Apache和Nginx的比較LinuxApacheNginx
- nginx關於root與alias的區別Nginx
- Apache Hadoop管理認證培訓(Cloudera)ApacheHadoopCloud
- Basic認證和Bearer Token認證的區別
- Apache Spark和Hive有用的功能ApacheSparkHive
- kafka SASL認證介紹及自定義SASL PLAIN認證功能KafkaAI
- 偽靜態配置apache 和nginxApacheNginx
- nginx配置kibana訪問使用者名稱和密碼認證、及無認證訪問配置Nginx密碼
- 在nginx location中用alias代理檔案Nginx
- mysql和apache不認識phpMySqlApachePHP
- oracle os認證和口令檔案認證的簡要解析Oracle
- 關於os認證和口令檔案認證
- 基於MySQL的Apache使用者認證例項(轉)MySqlApache
- 配置apache和nginx的tomcat負載均衡ApacheNginxTomcat負載
- 透過整合行業的光纖認證功能實現光纖認證智慧化行業
- 【登陸認證】oracle的作業系統認證和口令檔案認證方式(轉載)Oracle作業系統
- Cloudera Certified Administrator for Apache Hadoop(CCAH認證)CloudApacheHadoop
- [翻譯-Shiro]-Apache Shiro Java認證指南ApacheJava
- Nginx和Apache有什麼區別?NginxApache
- 關於os認證和口令檔案認證(轉)
- Nginx vs ApacheNginxApache
- Go語法要增加一個alias的功能Go
- 證書的數字簽名和認證 (轉)
- Nginx/Tomcat/Apache的優缺點和區別NginxTomcatApache
- Nginx接收的host值會影響alias的規則匹配Nginx
- Nginx 學習系列(三) ------------- alias、root指令區別Nginx