摘要:之前寫過重定向了,,但當(dāng)時比較模糊。這里主要說兩種常用的重定向,都是中的重定向。我測了下,這樣其實就搞定了,重定向就好了,不要向網(wǎng)上說的個語句。這里重定向到后,解析的的規(guī)則用的又是上面用到的,原理也一樣,把分割,然后匹配。
http://homeway.me
之前寫過Nginx重定向了,http://homeway.me/2014/10/28/nginx-reverse-proxy-conf/,但當(dāng)時比較模糊。
這里主要說兩種常用的重定向,都是php中的重定向。
一種是typecho的帶 index.php 例如 http://homeway.me/index.php/arg1/arg2,另一種是隱藏 index.php 的 http://homeway.me/arg1/arg2。
以下配置代碼均親測可用。
首先還是按常理,先腦補下nginx地rewrite規(guī)則,http://nginx.org/en/docs/http/ngx_http_rewrite_module.html
關(guān)于nginx重寫的指令主要由這么一些:
1. break指令 2. if指令 3. return指令 4. rewrite指令 5. rewrite_log指令 6. set指令
break指令
停止執(zhí)行當(dāng)前虛擬主機的后續(xù)rewrite指令集
if指令
對給定的條件condition進行判斷。如果為真,大括號內(nèi)的rewrite指令將被執(zhí)行。
有幾個要記住的操作符:
使用=,!= 比較的一個變量和字符串
是用~,~*與正則表達(dá)式匹配的變量,如果這個正則表達(dá)式中包含},;則整個表達(dá)式需要用" 或" 包圍
使用-f,!-f 檢查一個文件是否存在
使用-d,!-d 檢查一個目錄是否存在
使用-e,!-e 檢查一個文件、目錄、符號鏈接是否存在
使用-x,!-x 檢查一個文件是否可執(zhí)行
詳細(xì)中文看這里好了: http://www.nginx.cn/216.html
首先要明白我們現(xiàn)在要做的事情是兩類, /index.php/arg1/arg2 和 /arg1/arg2
1.類typecho的 /index.php/arg1/arg2/index.php/arg1/arg2 跑的location是index.php文件,也就是說,我們要做一個location匹配.php的正則,并且要讓它分辨出uri中的 /arg1/arg2
這個正則有很多種寫法,我用的是lnmp傳統(tǒng)的寫法~ [^/].php(/|$)。
完整匹配如下:
location ~ [^/].php(/|$) { #try_files $uri =404; 住址掃描目錄用的,這里我們都是虛假目錄,刪除。 fastcgi_split_path_info ^(.+.php)(/.+)$; fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_index index.php; include fastcgi.conf; #fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; #include fastcgi_params; }
我測了下,這樣其實就搞定了,typecho重定向就好了,不要向網(wǎng)上說的3個if語句。
只要訪問/index.php/arg1/arg2就能訪問到內(nèi)容了。
這里有幾個問題:
fastcgi_split_path_info干嘛用的?
去查找官網(wǎng)文檔吧, http://nginx.org/en/docs/http/ngx_http_fastcgi_module.html#fastcgi_spl...
Defines a regular expression that captures a value for the $fastcgi_path_info variable. The regular expression should have two captures: the first becomes a value of the $fastcgi_script_name variable, the second becomes a value of the $fastcgi_path_info variable.
也就是說,fastcgi_split_path_info 的作用就是把參數(shù)分割成 $fastcgi_script_name 和 $fastcgi_path_info,分割方式是后面的正則表達(dá)式。
我用echo模塊輸出了這里的參數(shù),得到下面的結(jié)果,上面的是不加fastcgi_split_path_info,下面是加了fastcgi_split_path_info的結(jié)果:
問題二,fastcgi.conf 和 fastcgi_params 是什么?
這里用到的這兩個配置文件是fastcgi的配置文件,我查看了下,發(fā)現(xiàn)fastcgi.conf和fastcgi_params的差別就在fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;這句話,也就是說,隨意選一個。
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param QUERY_STRING $query_string; fastcgi_param REQUEST_METHOD $request_method; fastcgi_param CONTENT_TYPE $content_type; fastcgi_param CONTENT_LENGTH $content_length; fastcgi_param SCRIPT_NAME $fastcgi_script_name; fastcgi_param REQUEST_URI $request_uri; fastcgi_param DOCUMENT_URI $document_uri; fastcgi_param DOCUMENT_ROOT $document_root; fastcgi_param SERVER_PROTOCOL $server_protocol; fastcgi_param HTTPS $https if_not_empty; fastcgi_param GATEWAY_INTERFACE CGI/1.1; fastcgi_param SERVER_SOFTWARE nginx/$nginx_version; fastcgi_param REMOTE_ADDR $remote_addr; fastcgi_param REMOTE_PORT $remote_port; fastcgi_param SERVER_ADDR $server_addr; fastcgi_param SERVER_PORT $server_port; fastcgi_param SERVER_NAME $server_name; fastcgi_param REDIRECT_STATUS 200;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;也就用到了之前的那個函數(shù)fastcgi_split_path_info,如果不做分割,就會回調(diào): No input file specified,沒有指定文件,就是因為$fastcgi_script_name的值找不到對應(yīng)的文件。
其實,我在conf里面添加了echo輸出,發(fā)現(xiàn)/index.php/arg1/arg2就只會訪問.php那個location。
然后,/arg1/arg2就用到了網(wǎng)上廣為流傳的那個typecho配置了:
location / { index index.html index.php; if (-f $request_filename/index.html){ rewrite (.*) $1/index.html break; } if (-f $request_filename/index.php){ rewrite (.*) $1/index.php; } if (!-f $request_filename){ rewrite (.*) /index.php; } }
看看就明白,目錄/arg1/arg2,不會有有index.php可以匹配.php后綴,所以只能匹配到 / 里面。
同樣地,這里我用echo模塊把參數(shù)輸出了下:
測試配置文件如下:
location / { index index.html index.php; if (-f $request_filename/index.html){ rewrite (.*) $1/index.html break; } if (-f $request_filename/index.php){ echo "request_filename -f index.php = $request_filename"; echo "request_filename -f index.php= $request_filename"; echo "fastcgi_path_info -f index.php = $fastcgi_path_info"; #rewrite (.*) $1/index.php; } if (!-f $request_filename){ echo "request_filename !-f index.php = $request_filename"; echo "fastcgi_script_name !-f index.php = $fastcgi_script_name"; echo "fastcgi_path_info !-f index.php = $fastcgi_path_info"; #rewrite (.*) /index.php; } }
測試的結(jié)果如下:
也就是訪問了第3個if語句,發(fā)現(xiàn)沒有/ajax這個文件,就重定向到/index.php去了。
這里重定向到/index.php后,解析.php的fastcgi的規(guī)則用的又是上面用到的,原理也一樣,把uri分割,然后匹配。
配置代碼如下:
location ~ [^/].php(/|$) { #try_files $uri =404; 住址掃描目錄用的,這里我們都是虛假目錄,刪除。 fastcgi_split_path_info ^(.+.php)(/.+)$; fastcgi_pass unix:/tmp/php-cgi.sock; fastcgi_index index.php; include fastcgi.conf; #fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; #include fastcgi_params; }
嗯...今天就算是,重新證明了下,網(wǎng)上流傳的那種,3個if語句的typecho語句,其實并沒有什么卵用。
最后進去的/index.php/2015/05/22/并不會去查詢 / 的location匹配,而是.php的正則匹配。
nginx的模塊測試都比較麻煩,都要重新編譯安裝,關(guān)于echo模塊調(diào)試起來比較方便。
http://wiki.nginx.org/HttpEchoModule
下面是一些if判斷用得到的nginx參數(shù),可以通過echo輸出測試查看:
$args $content_length $content_type $document_root $document_uri $host $http_user_agent $http_cookie $limit_rate $request_body_file $request_method $remote_addr $remote_port $remote_user $request_filename $request_uri $query_string $scheme $server_protocol $server_addr $server_name $server_port $uri
代碼我保存了一份,可以點擊鏈接下載:http://homeway.me/code/nginx-rewrite-conf.zip
-by小草
2015-05-22 18:27:10
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/39153.html
摘要:如果狀態(tài)碼附帶文字段落,該文本將被放置在響應(yīng)主體。相反,如果狀態(tài)碼后面是一個,該將成為頭部值。沒有狀態(tài)碼的將被視為一個狀態(tài)碼,這種情況下需要以或者開頭。因為和不能簡單的只返回狀態(tài)碼,還必須有重定向的,這就是指令無法返回的原因了。 HTTP模塊(核心模塊,也是主要用到的模塊) server模塊 server模塊是http的子模塊,它用來定義一個虛擬主機 例子: server { ...
概述 重寫URL是非常有用的一個功能,因為它可以讓你提高搜索引擎閱讀和索引你的網(wǎng)站的能力;而且在你改變了自己的網(wǎng)站結(jié)構(gòu)后,無需要求用戶修改他們的書簽,無需其他網(wǎng)站修改它們的友情鏈接;它還可以提高你的網(wǎng)站的安全性;而且通常會讓你的網(wǎng)站更加便于使用和更專業(yè)。 Nginx Rewrite規(guī)則相關(guān)指令 Nginx Rewrite規(guī)則相關(guān)指令有if、rewrite、set、return、break等,其中r...
摘要:但是使用重定向,瀏覽器鏈接是會發(fā)生變化的。第二種反向代理有些場景需要內(nèi)容重定向到另外一個但是鏈接保持不變,這時候就可以利用反向代理配置來達(dá)到目的。這里只是針對反向代理配置的一個投機利用,如果不理解反向代理,一定請自行學(xué)習(xí)。 第一種:rewrite 按照常規(guī)理解,實現(xiàn)重定向就是要用rewrite來實現(xiàn),例如demo:showImg(https://segmentfault.com/img...
摘要:非標(biāo)準(zhǔn)碼關(guān)閉連接而不發(fā)送響應(yīng)報頭。指令按照它們在配置文件中出現(xiàn)的順序執(zhí)行??梢允褂脴?biāo)志來終止指令的進一步處理。返回永久重定向。發(fā)送如下請求控制是否記錄有關(guān)未初始化變量的警告。 之前在配置nginx時,總是遇到rewrite指令的last和break標(biāo)識的問題,看到的資料大都是last 基本上都用這個 Flag,break 中止 Rewirte,不在繼續(xù)匹配??赐曛筮€是有點懵,后來看了...
閱讀 2821·2021-10-26 09:48
閱讀 1691·2021-09-22 15:22
閱讀 4071·2021-09-22 15:05
閱讀 626·2021-09-06 15:02
閱讀 2618·2019-08-30 15:52
閱讀 2120·2019-08-29 18:38
閱讀 2769·2019-08-28 18:05
閱讀 2339·2019-08-26 13:55