源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

Nginx中定义404页面并且返回404状态码的正确方法

  • 时间:2021-02-15 03:30 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Nginx中定义404页面并且返回404状态码的正确方法
前几天,一朋友出程序出问题却怎么查都没看出问题,于是让我帮它看看。其实它是ajax请求了很多个模板,然后把模板写到页面中。关键是所有请求的页面都是200正常状态码返回,表面上看没什么问题,实际上有些请求虽然返回200状态码,但给回的状态码是200。WebServer是nginx,直接告诉我应该他们配置了nginx的404错误页面,虽然请求不存在的资源可以成功返回404页面,但返回状态码确是200。 404.html
[u]复制代码[/u] 代码如下:
This is 404 page.
请求一个不存在的页面: [img]http://files.jb51.net/file_images/article/201408/2014082211143410.jpg[/img] 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(","));
    }
});
执行结果: [img]http://files.jb51.net/file_images/article/201408/2014082211143511.jpg[/img] 进入Object看看详细: [img]http://files.jb51.net/file_images/article/201408/2014082211143512.jpg[/img] 找不到请求的页面并返回404页面信息,但状态码依然是200,所以jQuery没有走[code]error[/code]函数回调而是直接走[code]success[/code]回调了。 应该是配置写的有问题,于是打开nginx.conf,发现他们配置这么写:
[u]复制代码[/u] 代码如下:
error_page  404  =  /404.html;
于是我查阅官网文档,把上面的表达式改写为:
[u]复制代码[/u] 代码如下:
error_page  404     /404.html;
然后重启
[u]复制代码[/u] 代码如下:
D:\nginx-1.5.11>nginx.exe -s reload
再来试试: [img]http://files.jb51.net/file_images/article/201408/2014082211143513.jpg[/img] 再来看看ajax请求的: [img]http://files.jb51.net/file_images/article/201408/2014082211143614.jpg[/img] 明显看到相比前面那条返回标红404状态码,下面console.log出来的是
[u]复制代码[/u] 代码如下:
[object Object],error,Not Found
然后点击进入Object看看: [img]http://files.jb51.net/file_images/article/201408/2014082211143615.jpg[/img] status值是404。既实现返回404页面,又能返回404状态码让ajax请求能够根据状态码判断页面请求状况进行错误处理。 (本文完)
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部