ngx Lua模組中的重定向

2021-07-12 07:34:00 字數 2165 閱讀 5241

在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 /foo 

location @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...