ningx lua 模組官方文件
nginx lua 模組原理和函式
在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
")
**:
node 重定向 express 重定向
服務端重定向對非同步請求無效 如何通過伺服器讓客戶端重定向 1.狀態碼設定為302 臨時重定向,301永久重定向 瀏覽器會記住 當再次請求相同位址的時候,瀏覽器不會重新請求該位址,會直接跳轉上一次請求該位址時的重定向位址 res.statuscode 2.在響應頭中通過 location 告訴客戶端...
輸入重定向,正確輸出重定向,錯誤輸出重定向
一 標準輸入 stdin a.輸入重定向 標準輸入 作用 將原先鍵盤輸入的內容改由檔案內容代替 root wenwen cat test.txt asdas asdas asdas 按crtl d 退出 將network內容匯入到test.txt中去 root wenwen cat test.txt...
icmp重定向實驗ensp icmp重定向實驗
一 實驗拓撲圖 二 實驗要求 三 實驗步驟配置 1 配置r0 r1 r2 r3的ip位址 r0 int f0 0 ip add 10.1.1.1 255.0.0.0 no sh r1 int f0 0 ip add 10.2.2.2 255.0.0.0 no sh r2 int f0 0 ip ad...