一、獲取 header?請求頭
- 在 ngx_lua 中訪問 Nginx 內(nèi)置變量 ngx.var.http_HEADER 即可獲得請求頭HEADER的內(nèi)容。
- 在 nginx配置中,通過$http_HEADER 即可獲得請求頭HEADER的內(nèi)容。
案例:
$.ajax({
.......
headers: {
Accept: "application/json; charset=utf-8",
X-TimerLocal: "Bin" //這個是自定義的請求頭
},
.......
});
在nginx的location配置中,在獲取header配置時,須要在header名稱前面加上固定前綴“http_“,并將header名稱中的“-”中劃線變?yōu)橄聞澗€,舉例說明:
? ? ? ?自定義的header名稱為X-TimerLocal,那在nginx中使用$http_x_timerlocal 來獲取到X-TimerLocal的值。
if ($http_x_timerlocal? = 'BIN') {
rewrite ^(.*/timerbin/.*)$ https://$host$1 permanent;
}
包含X-TimerLocal=BIN的header請求進(jìn)行判斷,若是發(fā)現(xiàn)路徑中包含/timerbin/路徑時,對請求URL進(jìn)行重寫,從新跳轉(zhuǎn)。
二、獲取url參數(shù)
- 在 ngx_lua 中訪問 Nginx 內(nèi)置變量 ngx.var.arg_PARAMETER 即可獲得GET參數(shù)PARAMETER的內(nèi)容。
- 在 nginx配置中,通過$arg_PARAMETER 即可獲得GET參數(shù)PARAMETER的內(nèi)容。
案例:
通過 http://www.test.com?name=hello&id=123 來驗證url的請求參數(shù),能夠在nginx中獲取到,只需要修改nginx.conf 配置文件如下,就可以在access.log中看到id和name在log中
http {
? ? include ? ? ? mime.types;
? ? default_type ?application/octet-stream;
? ? log_format main '{ "@timestamp": "$time_iso8601", '
? ? '"servername": "$http_host", '
? ? '"id": "$arg_id",'
? ? '"name": "$arg_name",'
? ? '"remote_addr": "$remote_addr",'
? ? '"referer": "$http_referer",'
? ? '"request": "$request",'
? ? '"request_time": "$request_time",'
? ? '"status": $status,'
? ? '"bytes":$body_bytes_sent,'
? ? '"agent": "$http_user_agent",'
? ? '"x_forwarded": "$http_x_forwarded_for",'
? ? '"upstr_addr": "$upstream_addr",'
? ? '"upstr_host": "$upstream_http_host",'
? ? '"ups_resp_time": "$upstream_response_time" }';文章來源:http://www.zghlxwxcb.cn/news/detail-443511.html
? ? access_log ?logs/access.log main;
? ? server_names_hash_bucket_size 128;
?文章來源地址http://www.zghlxwxcb.cn/news/detail-443511.html
到了這里,關(guān)于Nginx 獲取自定義請求header頭和URL參數(shù)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!