在nginx中實現重定向可以通過rewrite指令,具體可參考《nginx學習——http_rewrite_module的rewrite指令》
通過lua模組也可以實現同樣的功能,lua模組提供了相關的api來實現重定向的功能,主要有:
>ngx.exec
語法:ngx.exec(uri, args?)
主要實現的是內部的重定向,等價於下面的rewrite指令
rewrite regrex replacement last;
例子:
ngx.exec('/some-location');ngx.exec('/some-location', 'a=3&b=5&c=6');
ngx.exec('/some-location?a=3&b=5', 'c=6');
注意:1. 如果給定的uri是命名的location,那麼args就會被自動忽略的,如下所示:
location /foolocation @bar
2. args引數可以以string的形式給出,也可以以lua table的形式給出,如下所示:
ngx.exec(
"/foo"
,"a=3&b=hello%20world")
ngx.exec(
"/foo",)
3. 該方法不會主動返回,因此,強烈建議在呼叫該方法時,最好顯示加上return,如下所示:
return ngx.exec(...)
4. 該方法不像ngx.redirect方法,不會產生額外的網路流量。
>ngx.redirect
語法:ngx.redirect(uri, status?)
該方法會給客戶端返回乙個301/302重定向,具體是301還是302取決於設定的status值,如果不指定status值,預設是返回302 (ngx.http_moved_temporarily
),其等價於下面的rewrite指令:
rewrite
^ /foo? permanent;
# nginx config
如果返回301,那麼等價於下面的rewrite指令:
rewrite
^ /foo? redirect;
# nginx config
要注意與ngx.location.capture*的區別
ngx.location.capture*主要是通過子請求的方式實現location的重新定位的,它與上面的兩種方法完全不同的。
語法: ngx.req.set_uri(uri, jump?)
通過引數uri重寫當前請求的uri;引數jump,表明是否進行locations的重新匹配。當jump為true時,呼叫ngx.req.set_uri後,nginx將會根據修改後的uri,重新匹配新的locations;如果jump為false,將不會進行locations的重新匹配,而僅僅是修改了當前請求的uri而已。jump的預設值為false。
jump為true,等價於rewrite...last
jump為false,等價於rewrite...break
例如:ngx.req.set_uri(
"/foo"
, true)
等價於
rewrite ^ /foo last;
rewrite ^ /foo break;
等價於
ngx.req.set_uri(
"/foo", false
) 或 ngx.req.set_uri(
"/foo"
)
JMeter中的跟隨重定向自動重定向
自動重定向 httpclient 接受到請求後,如果請求中包含重定向請求,httpclient是可以自動跳轉的,但是只是針對get與head請求,勾選此項 跟隨重定向 失效 自動重定向可以自動跳轉到最終目標頁面,jmeter不記錄重定向過程內容,只有乙個最終結果,不能對相應內容做關聯。跟隨重定向 h...
Linux中重定向 追加重定向與輸入重定向
簡單介紹一下重定向 追加重定向與輸入重定向,輸入追加重定向的用法 重定向 我們可以將想要輸出的內容通過重定向新增到某個檔案中 ps 將hello寫入到當前資料夾下的a.txt檔案中,然後檢視a.txt檔案內容 追加重定向 追加重定向和重定向大致相同,不同點是追加重定向在檔案的基礎上繼續新增內容 ps...
ngx Lua模組中的加密api介面
在lua模組中提供了多種用於是實現各種字串加密演算法的api介面,主要包括 ngx.crc32 short 語法 digest ngx.crc32 short str 該方法主要是計算給定字串str的迴圈校驗碼 cyclic redundancy code 的摘要,計算出來的結果是乙個很大的整數 n...