Nginx实现404页面的几种方法

style=”font-family: 黑体; font-size: 15px”>server {

style=”font-family: 黑体; font-size: 15px”>listen    
 80;

style=”font-family: 黑体; font-size: 15px”>server_name
 www.test.com;

style=”font-family: 黑体; font-size: 15px”>root  
/var/www/test;

style=”font-family: 黑体; font-size: 15px”>index  index.html
index.htm;

style=”font-family: 黑体; font-size: 15px”>location /
{

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>#
定义错误页面码,如果出现相应的错误页面码,转发到那里。

style=”font-family: 黑体; font-size: 15px”>error_page  404 403 500
502 503 504  /404.html;

style=”font-family: 黑体; font-size: 15px”>#
承接上面的location。

style=”font-family: 黑体; font-size: 15px”>location = /404.html
{

style=”font-family: 黑体; font-size: 15px”>#
放错误页面的目录路径。

style=”font-family: 黑体; font-size: 15px”>root  
/usr/share/nginx/html;

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>}

第二种:反向代理的错误页面

如果后台Tomcat处理报错抛出404,想把这个状态叫Nginx反馈给客户端或者重定向到某个连接,配置如下:

第一种:Nginx自己的错误页面

看下面的配置,这种情况下不需要修改任何参数,就能实现这个功能。

一个网站项目,肯定是避免不了404页面的,通常使用Nginx作为Web服务器时,有以下集中配置方式,一起来看看。

style=”font-family: 黑体; font-size: 15px”>error_page    404
 /404.html;

style=”font-family: 黑体; font-size: 15px”>location = /404.html
{

style=”font-family: 黑体; font-size: 15px”>root  
/usr/share/nginx/html;

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>error_page 404
 /404.html;

style=”font-family: 黑体; font-size: 15px”>error_page 404 =
http://www.test.com/error.html;

style=”font-family: 黑体; font-size: 15px”>文章来自:http://www.yunweipai.com/archives/22238.html

在http段中加一个变量 fastcgi_intercept_errors
on 就可以了。

指定一个url地址:

style=”font-family: 黑体; font-size: 15px”>upstream www
{

style=”font-family: 黑体; font-size: 15px”>server 192.168.1.201:7777
 weight=20 max_fails=2 fail_timeout=30s;

style=”font-family: 黑体; font-size: 15px”>ip_hash;

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>server {

style=”font-family: 黑体; font-size: 15px”>listen      
80;

style=”font-family: 黑体; font-size: 15px”>server_name
www.test.com;

style=”font-family: 黑体; font-size: 15px”>root  
/var/www/test;

style=”font-family: 黑体; font-size: 15px”>index  index.html
index.htm;

style=”font-family: 黑体; font-size: 15px”> 

style=”font-family: 黑体; font-size: 15px”>location /
{

style=”font-family: 黑体; font-size: 15px”>if ($request_uri ~*
‘^/$’) {

style=”font-family: 黑体; font-size: 15px”>rewrite .*  
http://www.test.com/index.html redirect;

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>#
关键参数:这个变量开启后,我们才能自定义错误页面,当后端返回404,nginx拦截错误定义错误页面

style=”font-family: 黑体; font-size: 15px”>proxy_intercept_errors
on;

style=”font-family: 黑体; font-size: 15px”>proxy_pass    
 http://www;

style=”font-family: 黑体; font-size: 15px”>proxy_set_header HOST  
$host;

style=”font-family: 黑体; font-size: 15px”>proxy_set_header
X-Real-IP      $remote_addr;

style=”font-family: 黑体; font-size: 15px”>proxy_set_header
X-Forwarded-FOR $proxy_add_x_forwarded_for;

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>error_page    404
 /404.html;

style=”font-family: 黑体; font-size: 15px”>location = /404.html
{

style=”font-family: 黑体; font-size: 15px”>root  
/usr/share/nginx/html;

style=”font-family: 黑体; font-size: 15px”>}

style=”font-family: 黑体; font-size: 15px”>}

指定一个错误页面:

Nginx访问一个静态的html
页面,当这个页面没有的时候,Nginx抛出404,那么如何返回给客户端404呢?

如果后端是php解析的,需要加一个变量

第三种:Nginx解析php代码的错误页面