Nginx根據url參數重定向


 

1. 判斷url路徑

location / { if ($args ~* "/product-list?param1=val1&param2=val2") { rewrite ^ http://www.mysite.com/product-list/$arg_param1/$arg_param2? last; } } 

2. 判斷url參數

if ($arg_path = 'abc'){ proxy_pass http://127.0.0.1/abc/$arg_path; } 

特別注意if is evil,nginx不提供多if判斷,沒有or這樣的判斷,所以只能用下文這種方式。

location /api/ { if ($arg_token = '') { proxy_pass http://127.0.0.1/abc } if ($http_token = '') { proxy_pass http://127.0.0.2/abc } if ($token = paraheader) { proxy_pass http://127.0.0.3/abc } proxy_pass http://127.0.0.1:8080/app/; proxy_redirect off; } 

3. 其他參數

$arg_PARAMETER #這個變量包含GET請求中,如果有變量PARAMETER時的值。 $args #這個變量等於請求行中(GET請求)的參數,例如foo=123&bar=blahblah; $binary_remote_addr #二進制的客戶地址。 $body_bytes_sent #響應時送出的body字節數數量。即使連接中斷,這個數據也是精確的。 $content_length #請求頭中的Content-length字段。 $content_type #請求頭中的Content-Type字段。 $cookie_COOKIE #cookie COOKIE變量的值 $document_root #當前請求在root指令中指定的值。 $document_uri #與$uri相同。 $host #請求主機頭字段,否則為服務器名稱。 $hostname #Set to the machine’s hostname as returned by gethostname $http_HEADER $is_args #如果有$args參數,這個變量等於”?”,否則等於”",空值。 $http_user_agent #客戶端agent信息 $http_cookie #客戶端cookie信息 $limit_rate #這個變量可以限制連接速率。 $query_string #與$args相同。 $request_body_file #客戶端請求主體信息的臨時文件名。 $request_method #客戶端請求的動作,通常為GET或POST。 $remote_addr #客戶端的IP地址。 $remote_port #客戶端的端口。 $remote_user #已經經過Auth Basic Module驗證的用戶名。 $request_completion #如果請求結束,設置為OK. 當請求未結束或如果該請求不是請求鏈串的最后一個時,為空(Empty)。 $request_method #GET或POST $request_filename #當前請求的文件路徑,由root或alias指令與URI請求生成。 $request_uri #包含請求參數的原始URI,不包含主機名,如:”/foo/bar.php?arg=baz”。不能修改。 $scheme #HTTP方法(如http,https)。 $server_protocol #請求使用的協議,通常是HTTP/1.0或HTTP/1.1。 $server_addr #服務器地址,在完成一次系統調用后可以確定這個值。 $server_name #服務器名稱。 $server_port #請求到達服務器的端口號。 $uri #不帶請求參數的當前URI,$uri不包含主機名,如”/foo/bar.html”。該值有可能和$request_uri 不一致。$request_uri是瀏覽器發過來的值。該值是rewrite后的值。例如做了internal redirects后。 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM