當80和443配在一個server裏,就應該下面這麼寫,
if($scheme = http){
rewrite ^/(.*)$ https://www.jd.com/$1 permanent;
}
錯誤寫法,不寫判斷,那就會一直rewrite
rewrite / https://www.jd.com permanent;
官方推薦寫成兩個server,更優雅
server {
listen 80;
server_name www.nginx.org;
......
}
server {
listen 80;
server_name nginx.org;
rewrite ^ http://www.nginx.org$request_uri?;
}
參考:https://www.iteye.com/blog/limimgjie-744579
Nginx提供了很多內置的變量,如:
$arg_PARAMETER 這個變量包含在查詢字符串時GET請求PARAMETER的值。
$args 這個變量等於請求行中的參數。
$binary_remote_addr 二進制碼形式的客戶端地址。
$body_bytes_sent 傳送頁面的字節數
$content_length 請求頭中的Content-length字段。
$content_type 請求頭中的Content-Type字段。
$cookie_COOKIE cookie COOKIE的值。
$document_root 當前請求在root指令中指定的值。
$document_uri 與$uri相同。
$host 請求中的主機頭字段,如果請求中的主機頭不可用,則爲服務器處理請求的服務器名稱。
$is_args 如果$args設置,值爲"?",否則爲""。
$limit_rate 這個變量可以限制連接速率。
$nginx_version 當前運行的nginx版本號。
$query_string 與$args相同。
$remote_addr 客戶端的IP地址。
$remote_port 客戶端的端口。
$remote_user 已經經過Auth Basic Module驗證的用戶名。
$request_filename 當前連接請求的文件路徑,由root或alias指令與URI請求生成。
$request_body 這個變量(0.7.58+)包含請求的主要信息。在使用proxy_pass或fastcgi_pass指令的location中比較有意義。
$request_body_file 客戶端請求主體信息的臨時文件名。
$request_completion 未知。
$request_method 這個變量是客戶端請求的動作,通常爲GET或POST。
包括0.8.20及之前的版本中,這個變量總爲main request中的動作,如果當前請求是一個子請求,並不使用這個當前請求的動作。
$request_uri 這個變量等於包含一些客戶端請求參數的原始URI,它無法修改,請查看$uri更改或重寫URI。
$scheme 所用的協議,比如http或者是https,比如rewrite ^(.+)$ $scheme://example.com$1 redirect;
$server_addr 服務器地址,在完成一次系統調用後可以確定這個值,如果要繞開系統調用,則必須在listen中指定地址並且使用bind參數。
$server_name 服務器名稱。
$server_port 請求到達服務器的端口號。
$server_protocol 請求使用的協議,通常是HTTP/1.0或HTTP/1.1。
$uri 請求中的當前URI(不帶請求參數,參數位於$args),可以不同於瀏覽器傳遞的$request_uri的值,它可以通過內部重定向,或者使用index指令進行修改。
另外:
HTTP_X_FORWARDED_FOR是透過代理服務器取得客戶端的真實IP地址,有些用此方法讀取到的仍然是代理服務器的IP。還有一點需要注意的是:如果客戶端沒有通過代理服務器來訪問,那麼用 HTTP_X_FORWARDED_FOR 取到的值將是空的。