Nginx SSI支持配置

什么是SSI

Server Side Include,通常称为服务器端嵌入,是一种类似于ASP的基于服务器的网页制作技术。大多数(尤其是基于Unix平台)的WEB服务器如Netscape Enterprise Server等均支持SSI命令。

为什么要用SSI

用个例子来说明,一个静态化的页面中,需要嵌入一小块实时变化的内容,。例如首页,大部分的页面内容需要缓存但是用户登录后的个人信息是动态信息,不能缓存。那么如何解决这个”页面部分缓存”问题,利用SSI就可以解决,在首页的静态页面中嵌入个人信息的动态页,由于是服务器端的嵌入,所以用户浏览的时候都是一个嵌入后的页面。

nginx配置SSI

nginx 默认就自带了 SSI,不需要安装任何组件模块。

主要是三个参数,ssi,ssi_silent_errors和ssi_types,均可以放在http,server和location的作用域下。

ssi on

开启ssi支持,默认是off

ssi_silent_errors on

默认值是off,开启后在处理SSI文件出错时不输出错误提示:”[an error occurred while processing the directive] ”

ssi_types

默认是ssi_types text/html,所以如果需要htm和html支持,则不需要设置这句,如果需要shtml支持,则需要设置:ssi_types text/shtml

案例:

修改nginx.conf配置文件增加以下内容:

      ssi配置,可以放在http,server和location的作用域下,当前放到了location下了

location / {
    root   html;
    #ssi配置开始
    ssi on;  
    ssi_silent_errors on;  
    ssi_types text/shtml;  
    #ssi配置结束         
    index  index.html index.htm;
}

编写文件a.html

<html>
    <head>
    </head>
    <body>
    A.OK
    <!--引入b.html-->
    <!--# include file="b.html" -->
    </body>
</html>

编写文件b.html

<html>
<head>
</head>
<body>
B.OK
</body>
</html>

    把编写的两个html都放到nginx的html目录中,并通过浏览器访问(http://localhost/a.html),得到以下页面:

可以看到A页面中引入了B页面的内容

猜你喜欢

转载自my.oschina.net/sdlvzg/blog/1816685