Nginx中404頁面的配置及AJAX請求返回404頁面的方法
404頁面基礎配置
404錯誤是WWW網(wǎng)站訪問容易出現(xiàn)的錯誤。最常見的出錯提示:404 NOT FOUND。404錯誤頁的設置對網(wǎng)站SEO有很大的影響,而設置不當,比如直接轉跳主頁等,會被搜索引擎降權拔毛。404頁面的目的應該是告訴用戶:你所請求的頁面是不存在的,同時引導用戶瀏覽網(wǎng)站其他頁面而不是關掉窗口離去。搜索引擎通過HTTP狀態(tài)碼來識別網(wǎng)頁的狀態(tài)。當搜索引擎獲得了一個錯誤鏈接時,網(wǎng)站應該返回404狀態(tài)碼,告訴搜索引擎放棄對該鏈接的索引。而如果返回200或302狀態(tài)碼,搜索引擎就會為該鏈接建立索引,這導致大量不同的鏈接指向了相同的網(wǎng)頁內(nèi)容。結果是,搜索引擎對網(wǎng)站的信任度大幅降低。
下面是LNMP設置Nginx 404錯誤頁教程:
1、
vi /usr/local/nginx/conf/nginx.conf
編輯Nginx配置文件,在http 區(qū)段添加下面代碼:
fastcgi_intercept_errors on;
2、編輯網(wǎng)站配置文件,比如本站:
vi /usr/local/nginx/conf/vhost/onelone.com.conf
,在server 區(qū)段添加下面代碼:
error_page 404 = /404.html;
注意:有網(wǎng)友測試上行代碼需要去掉等號才會返回正確的404狀態(tài),所以請同學們自行測試是否要去掉等號。
3、測試配置文件是否正確:
/usr/local/nginx/sbin/nginx -t
,返回下面代碼通過:
the configuration file /usr/local/nginx/conf/nginx.conf syntax is ok configuration file /usr/local/nginx/conf/nginx.conf test is successful
4、重啟LNMP生效:/root/lnmp restart 。
5、404錯誤頁面制作的注意事項:
(1)不要將404錯誤轉向到網(wǎng)站主頁,否則可能會導致主頁在搜索引擎中被降權或消失。
(2)不要使用絕對URL,如果使用絕對URL返回的狀態(tài)碼是302+200,這樣會產(chǎn)生大量的重復網(wǎng)頁。
(3)404頁面設置完成,一定要檢查是否正確。http頭信息返回的一定要是404狀態(tài)。這個可以通過服務器頭部信息檢查工具進行檢查。
(4)404頁面不要自動跳轉,讓用戶來決定去向。
自定義的404頁面必須大于512字節(jié),否則可能會出現(xiàn)IE默認的404頁面。
AJAX請求的404頁面返回
前幾天,一朋友出程序出問題卻怎么查都沒看出問題,于是讓我?guī)退纯?。其實它是ajax請求了很多個模板,然后把模板寫到頁面中。關鍵是所有請求的頁面都是200正常狀態(tài)碼返回,表面上看沒什么問題,實際上有些請求雖然返回200狀態(tài)碼,但給回的狀態(tài)碼是200。WebServer是nginx,直接告訴我應該他們配置了nginx的404錯誤頁面,雖然請求不存在的資源可以成功返回404頁面,但返回狀態(tài)碼確是200。
404.html This is 404 page.
請求一個不存在的頁面:
ajax Code:
$.ajax({ url: "does_not_exist.html", success : function(Response, textStatus){ console.log(textStatus+":"+Response); }, error : function(XMLHttpRequest, textStatus, errorThrown){ console.log([XMLHttpRequest, textStatus, errorThrown].join(",")); } });
執(zhí)行結果:
進入Object看看詳細:
找不到請求的頁面并返回404頁面信息,但狀態(tài)碼依然是200,所以jQuery沒有走error函數(shù)回調(diào)而是直接走success回調(diào)了。
應該是配置寫的有問題,于是打開nginx.conf,發(fā)現(xiàn)他們配置這么寫:
error_page 404 = /404.html;
于是我查閱官網(wǎng)文檔,把上面的表達式改寫為:
error_page 404 /404.html;
然后重啟
D:\nginx-1.5.11>nginx.exe -s reload
再來試試:
再來看看ajax請求的:
明顯看到相比前面那條返回標紅404狀態(tài)碼,下面console.log出來的是
[object Object],error,Not Found
然后點擊進入Object看看:
status值是404。既實現(xiàn)返回404頁面,又能返回404狀態(tài)碼讓ajax請求能夠根據(jù)狀態(tài)碼判斷頁面請求狀況進行錯誤處理。
下面是其它網(wǎng)友的補充:
一.Nginx錯誤頁面優(yōu)雅顯示的原因?
當我們訪問網(wǎng)站時,由于特殊的原因,經(jīng)常會出現(xiàn)諸如403,404,503等錯誤,這極大的影響用戶的訪問體驗,所以我們很有必要做一下錯誤頁面的優(yōu)雅顯示,以提升用戶的瀏覽體驗。
二.Nginx下如何定義優(yōu)雅顯示的頁面呢?
下面我們就以404錯誤為例,具體步驟如下:
1.創(chuàng)建自己的404.html頁面,放在站點目錄下面;
2.更改nginx.conf配置文件,在http模塊中加入 fastcgi_intercept_errors on;
3.更改nginx.conf配置文件,在server模塊中加入:error_page 404 /404.html; 或者 error_page 404 =http://www.hulala.com/404.html;
4.更改后檢查語法/nginx/sbin/nginx -t ,并重啟nginx;
現(xiàn)在,404錯誤的頁面優(yōu)雅顯示已經(jīng)配置OK了。
舉一反三:502、403 等其他錯誤可以用同樣的方法來配置。
error_page 500 502 503 504 /50x.html;
error_page 403 /403.html;
注意:
在nginx中錯誤重定向生效的兩個前提條件是:設置了fastcgi_intercept_errors on,并且正確的設置了error_page這個選項。
相關文章
keepalived+lvs 對nginx做負載均衡和高可用的操作方法
這篇文章主要介紹了keepalived+lvs 對nginx做負載均衡和高可用的操作方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12Nginx中return和rewrite的寫法及區(qū)別淺析
在Nginx中,return和rewrite都用于重定向,但有所區(qū)別,return立即終止請求并返回指定HTTP狀態(tài)碼,不額外請求,rewrite則重寫URI并引發(fā)新請求,需要的朋友可以參考下2024-09-09