欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Nginx中404頁面的配置及AJAX請求返回404頁面的方法

 更新時(shí)間:2016年05月30日 15:25:03   作者:lizhong  
404是請求頁面不存在的錯(cuò)誤代碼,在Nginx中有時(shí)處理jQuery中的ajax方法雖然能返回404頁面但錯(cuò)誤代碼卻返回200,針對此問題我們具體來看一下Nginx中404頁面的配置及AJAX請求返回404頁面的方法

404頁面基礎(chǔ)配置
404錯(cuò)誤是WWW網(wǎng)站訪問容易出現(xiàn)的錯(cuò)誤。最常見的出錯(cuò)提示:404 NOT FOUND。404錯(cuò)誤頁的設(shè)置對網(wǎng)站SEO有很大的影響,而設(shè)置不當(dāng),比如直接轉(zhuǎn)跳主頁等,會被搜索引擎降權(quán)拔毛。404頁面的目的應(yīng)該是告訴用戶:你所請求的頁面是不存在的,同時(shí)引導(dǎo)用戶瀏覽網(wǎng)站其他頁面而不是關(guān)掉窗口離去。搜索引擎通過HTTP狀態(tài)碼來識別網(wǎng)頁的狀態(tài)。當(dāng)搜索引擎獲得了一個(gè)錯(cuò)誤鏈接時(shí),網(wǎng)站應(yīng)該返回404狀態(tài)碼,告訴搜索引擎放棄對該鏈接的索引。而如果返回200或302狀態(tài)碼,搜索引擎就會為該鏈接建立索引,這導(dǎo)致大量不同的鏈接指向了相同的網(wǎng)頁內(nèi)容。結(jié)果是,搜索引擎對網(wǎng)站的信任度大幅降低。
下面是LNMP設(shè)置Nginx 404錯(cuò)誤頁教程:
1、

vi /usr/local/nginx/conf/nginx.conf 

編輯Nginx配置文件,在http 區(qū)段添加下面代碼:

fastcgi_intercept_errors on;

2016530151450543.jpg (499×393)

2、編輯網(wǎng)站配置文件,比如本站:

vi /usr/local/nginx/conf/vhost/onelone.com.conf 

,在server 區(qū)段添加下面代碼:

error_page 404 = /404.html; 

注意:有網(wǎng)友測試上行代碼需要去掉等號才會返回正確的404狀態(tài),所以請同學(xué)們自行測試是否要去掉等號。

2016530151544231.jpg (639×358)

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 。

2016530151616741.jpg (661×433)

5、404錯(cuò)誤頁面制作的注意事項(xiàng):
(1)不要將404錯(cuò)誤轉(zhuǎn)向到網(wǎng)站主頁,否則可能會導(dǎo)致主頁在搜索引擎中被降權(quán)或消失。   
(2)不要使用絕對URL,如果使用絕對URL返回的狀態(tài)碼是302+200,這樣會產(chǎn)生大量的重復(fù)網(wǎng)頁。
(3)404頁面設(shè)置完成,一定要檢查是否正確。http頭信息返回的一定要是404狀態(tài)。這個(gè)可以通過服務(wù)器頭部信息檢查工具進(jìn)行檢查。
(4)404頁面不要自動跳轉(zhuǎn),讓用戶來決定去向。
自定義的404頁面必須大于512字節(jié),否則可能會出現(xiàn)IE默認(rèn)的404頁面。

AJAX請求的404頁面返回
前幾天,一朋友出程序出問題卻怎么查都沒看出問題,于是讓我?guī)退纯础F鋵?shí)它是ajax請求了很多個(gè)模板,然后把模板寫到頁面中。關(guān)鍵是所有請求的頁面都是200正常狀態(tài)碼返回,表面上看沒什么問題,實(shí)際上有些請求雖然返回200狀態(tài)碼,但給回的狀態(tài)碼是200。WebServer是nginx,直接告訴我應(yīng)該他們配置了nginx的404錯(cuò)誤頁面,雖然請求不存在的資源可以成功返回404頁面,但返回狀態(tài)碼確是200。

404.html
This is 404 page.

請求一個(gè)不存在的頁面:

2016530151656752.jpg (482×358)

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í)行結(jié)果:

2016530151719946.jpg (579×319)

進(jìn)入Object看看詳細(xì):

2016530151735924.jpg (520×631)

找不到請求的頁面并返回404頁面信息,但狀態(tài)碼依然是200,所以jQuery沒有走error函數(shù)回調(diào)而是直接走success回調(diào)了。
應(yīng)該是配置寫的有問題,于是打開nginx.conf,發(fā)現(xiàn)他們配置這么寫:

error_page 404 = /404.html;

于是我查閱官網(wǎng)文檔,把上面的表達(dá)式改寫為:

error_page 404 /404.html;

然后重啟

D:\nginx-1.5.11>nginx.exe -s reload

再來試試:

2016530151808375.jpg (513×386)

再來看看ajax請求的:

2016530151825213.jpg (589×431)

明顯看到相比前面那條返回標(biāo)紅404狀態(tài)碼,下面console.log出來的是

[object Object],error,Not Found

然后點(diǎn)擊進(jìn)入Object看看:

2016530151847320.jpg (459×620)

status值是404。既實(shí)現(xiàn)返回404頁面,又能返回404狀態(tài)碼讓ajax請求能夠根據(jù)狀態(tài)碼判斷頁面請求狀況進(jìn)行錯(cuò)誤處理。

 下面是其它網(wǎng)友的補(bǔ)充:

一.Nginx錯(cuò)誤頁面優(yōu)雅顯示的原因?
當(dāng)我們訪問網(wǎng)站時(shí),由于特殊的原因,經(jīng)常會出現(xiàn)諸如403,404,503等錯(cuò)誤,這極大的影響用戶的訪問體驗(yàn),所以我們很有必要做一下錯(cuò)誤頁面的優(yōu)雅顯示,以提升用戶的瀏覽體驗(yàn)。

二.Nginx下如何定義優(yōu)雅顯示的頁面呢?
下面我們就以404錯(cuò)誤為例,具體步驟如下:
1.創(chuàng)建自己的404.html頁面,放在站點(diǎn)目錄下面;
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錯(cuò)誤的頁面優(yōu)雅顯示已經(jīng)配置OK了。

舉一反三:502、403 等其他錯(cuò)誤可以用同樣的方法來配置。
error_page 500 502 503 504 /50x.html;
error_page 403 /403.html;
注意:
在nginx中錯(cuò)誤重定向生效的兩個(gè)前提條件是:設(shè)置了fastcgi_intercept_errors on,并且正確的設(shè)置了error_page這個(gè)選項(xiàng)。

相關(guān)文章

  • Nginx負(fù)載均衡配置簡單配置方法

    Nginx負(fù)載均衡配置簡單配置方法

    Nginx作為負(fù)載均衡服務(wù)器,用戶請求先到達(dá)nginx,再由nginx根據(jù)負(fù)載配置將請求轉(zhuǎn)發(fā)至不同的Web服務(wù)器。下面通過本文給大家分享Nginx負(fù)載均衡配置簡單配置方法,需要的的朋友參考下吧
    2017-08-08
  • 如何用Nginx解決前端跨域問題

    如何用Nginx解決前端跨域問題

    在開發(fā)靜態(tài)頁面時(shí),類似Vue的應(yīng)用,我們常會調(diào)用一些接口,這些接口極可能是跨域,這篇文章主要介紹了如何用Nginx解決前端跨域問題,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2019-01-01
  • keepalived+lvs 對nginx做負(fù)載均衡和高可用的操作方法

    keepalived+lvs 對nginx做負(fù)載均衡和高可用的操作方法

    這篇文章主要介紹了keepalived+lvs 對nginx做負(fù)載均衡和高可用的操作方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2023-12-12
  • 前端必備的一些nginx知識點(diǎn)匯總

    前端必備的一些nginx知識點(diǎn)匯總

    Nginx是一個(gè)高性能的HTTP和反向代理web服務(wù)器,同時(shí)也提供了IMAP/POP3/SMTP服務(wù),下面這篇文章主要給大家匯總介紹了關(guān)于前端必備的一些nginx知識點(diǎn),文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • nginx 版本升級的實(shí)現(xiàn)方法

    nginx 版本升級的實(shí)現(xiàn)方法

    文介紹了如何在CentOS7服務(wù)器上無中斷地將Nginx從1.18.0版本升級到1.19.7版本,提供了兩種升級方法,具有一定的參考價(jià)值,感興趣的可以了解一下
    2024-09-09
  • 一文弄懂Nginx熱升級

    一文弄懂Nginx熱升級

    Nginx熱升級指服務(wù)不中斷情況下用新的Nginx二進(jìn)制文件替換老的Nginx二進(jìn)制文件,本文就來介紹一下Nginx熱升級,感興趣的可以了解一下
    2024-05-05
  • Nginx中return和rewrite的寫法及區(qū)別淺析

    Nginx中return和rewrite的寫法及區(qū)別淺析

    在Nginx中,return和rewrite都用于重定向,但有所區(qū)別,return立即終止請求并返回指定HTTP狀態(tài)碼,不額外請求,rewrite則重寫URI并引發(fā)新請求,需要的朋友可以參考下
    2024-09-09
  • 利用nginx和騰訊云免費(fèi)證書制作https的方法

    利用nginx和騰訊云免費(fèi)證書制作https的方法

    這篇文章主要介紹了利用nginx和騰訊云免費(fèi)證書制作https的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-11-11
  • Nginx設(shè)置日志打印post請求參數(shù)的方法

    Nginx設(shè)置日志打印post請求參數(shù)的方法

    這篇文章主要介紹了Nginx設(shè)置日志打印post請求參數(shù)的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • nginx訪問返回504問題及解決

    nginx訪問返回504問題及解決

    這篇文章主要介紹了nginx訪問返回504問題及解決,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05

最新評論