1. 程式人生 > >nginx error_page

nginx error_page

1. error_page語法

語法:

error_page code [ code... ] [ = | =answer-code ] uri | @named_location 

預設值:

no 

使用欄位:

http, server, location, location 中的if欄位 

2. 例項

nginx指令error_page的作用是當發生錯誤的時候能夠顯示一個預定義的uri,比如:

error_page 502 503 /50x.html;
location = /50x.html {
    root /usr/share/nginx/html;
}   

這樣實際上產生了一個內部跳轉(internal redirect),當訪問出現502、503的時候就能返回50x.html中的內容,這裡需要注意是否可以找到50x.html頁面,所以加了個location保證找到你自定義的50x頁面。

同時我們也可以自己定義這種情況下的返回狀態嗎,比如:

error_page 502 503 =200 /50x.html;
location = /50x.html {
    root /usr/share/nginx/html;
}   

這樣使用者訪問產生502 、503的時候給使用者的返回狀態是200,內容是50x.html。

當error_page後面跟的不是一個靜態的內容的話,比如是由proxyed server或者FastCGI/uwsgi/SCGI server處理的話,server返回的狀態(200, 302, 401 或者 404)也能返回給使用者。

error_page 404 = /404.php;
location ~ \.php$ {
    fastcgi_pass 127.0.0.1:9000;
    fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
    include fastcgi_params;
}   

也可以設定一個named location,然後在裡邊做對應的處理。

error_page 500 502 503 504 @jump_to_error;
location @jump_to_error {    
    proxy_pass http://backend;
}

同時也能夠通過使客戶端進行302、301等重定向的方式處理錯誤頁面,預設狀態碼為302。

error_page 403      http://example.com/forbidden.html;
error_page 404 =301 http://example.com/notfound.html;

同時error_page在一次請求中只能響應一次,對應的nginx有另外一個配置可以控制這個選項:recursive_error_pages


預設為false,作用是控制error_page能否在一次請求中觸發多次。

2. Nginx 自定義404錯誤頁面配置中有無等號的區別

  • error_page 404 /404.html 可顯示自定義404頁面內容,正常返回404狀態碼。
  • error_page 404 = /404.html 可顯示自定義404頁面內容,但返回200狀態碼。
  • error_page 404 /404.php 如果是動態404錯誤頁面,包含 header 程式碼(例如301跳轉),將無法正常執行。正常返回404程式碼。
  • error_page 404 = /404.php 如果是動態404錯誤頁面,包含 header 程式碼(例如301跳轉),加等號配置可以正常執行,返回php中定義的狀態碼。但如果php中定義返回404狀態碼,404狀態碼可以正常返回,但無法顯示自定義頁面內容(出現系統預設404頁面),這種情況可以考慮用410程式碼替代( header("HTTP/1.1 410 Gone"); 正常返回410狀態碼,且可正常顯示自定義內容)。