1. 程式人生 > 其它 >nginx的location配置詳解:location匹配規則

nginx的location配置詳解:location匹配規則

nginx的location配置詳解:location匹配規則

location指令

server{
	listen 80;
	server_name localhost;
	location / {
	
	}
	location /abc{
	
	}
	...
}

location:用來設定請求的URI

預設值 —
語法 location [ = | ~ | ~* | ^~ |@ ] uri{...}
位置 server,location
uri變數是待匹配的請求字串,可以不包含正則表示式,也可以包含正則表示式,那麼nginx伺服器在搜尋匹配location的時候,是先使用不包含正則表示式進行匹配,找到一個匹配度最高的一個,然後在通過包含正則表示式的進行匹配,如果能匹配到直接訪問,匹配不到,就使用剛才匹配度最高的那個location來處理請求。

屬性介紹:

不帶符號,要求必須以指定模式開始


server {
	listen 80;
	server_name 127.0.0.1;
	location /abc{
		default_type text/plain;
		return 200 "access success";
	}
}
以下訪問都是正確的
http://192.168.200.133/abc
http://192.168.200.133/abc?p1=TOM
http://192.168.200.133/abc/
http://192.168.200.133/abcdef

= : 用於不包含正則表示式的uri前,必須與指定的模式精確匹配


server {
	listen 80;
	server_name 127.0.0.1;
	location =/abc{
		default_type text/plain;
		return 200 "access success";
	}
}
可以匹配到
http://192.168.200.133/abc
http://192.168.200.133/abc?p1=TOM
匹配不到
http://192.168.200.133/abc/
http://192.168.200.133/abcdef

~ : 用於表示當前uri中包含了正則表示式,並且區分大小寫

~*: 用於表示當前uri中包含了正則表示式,並且不區分大小寫

換句話說,如果uri包含了正則表示式,需要用上述兩個符合來標識

server {
	listen 80;
	server_name 127.0.0.1;
	location ~^/abc\w${
		default_type text/plain;
		return 200 "access success";
	}
}
server {
	listen 80;
	server_name 127.0.0.1;
	location ~*^/abc\w${
		default_type text/plain;
		return 200 "access success";
	}
}

^~: 用於不包含正則表示式的uri前,功能和不加符號的一致,唯一不同的是,如果模式匹配,那麼就停止搜尋其他模式了。


server {
	listen 80;
	server_name 127.0.0.1;
	location ^~/abc{
		default_type text/plain;
		return 200 "access success";
	}
}

設定請求資源的目錄root / alias

root:設定請求的根目錄

語法 root path;
預設值 root html;
位置 http、server、location

path為Nginx伺服器接收到請求以後查詢資源的根目錄路徑。

alias:用來更改location的URI

語法 alias path;
預設值
位置 location

path為修改後的根路徑。

以上兩個指令都可以來指定訪問資源的路徑,那麼這兩者之間的區別是什麼?

舉例說明:

(1)在/usr/local/nginx/html目錄下建立一個 images目錄,並在目錄下放入一張圖片mv.png圖片


location /images {
	root /usr/local/nginx/html;
}

訪問圖片的路徑為:

http://192.168.200.133/images/mv.png

(2)如果把root改為alias

location /images {
	alias /usr/local/nginx/html;
}

再次訪問上述地址,頁面會出現404的錯誤,檢視錯誤日誌會發現是因為地址不對,所以驗證了:

root的處理結果是: root路徑+location路徑
/usr/local/nginx/html/images/mv.png
alias的處理結果是:使用alias路徑替換location路徑
/usr/local/nginx/html/images

需要在alias後面路徑改為

location /images {
	alias /usr/local/nginx/html/images;
}

(3)如果location路徑是以/結尾,則alias也必須是以/結尾,root沒有要求

將上述配置修改為

location /images/ {
	alias /usr/local/nginx/html/images;
}

訪問就會出問題,檢視錯誤日誌還是路徑不對,所以需要把alias後面加上 /

小結:

root的處理結果是: root路徑+location路徑

alias的處理結果是:使用alias路徑替換location路徑

alias是一個目錄別名的定義,root則是最上層目錄的含義。

如果location路徑是以/結尾,則alias也必須是以/結尾,root沒有要求