在tomcat下使用ssi指令的配置以下:html
找到conf/context.xml这个文件,使用编辑器打开,在<Context>标签中加一句privileged="true",变成<Context privileged="true">java
找到conf/web.xml这个文件,使用编辑器打开,在文件中查找ssi(原文件中本来就有ssi的配置,只不过被注释了),找到后去掉有关配置ssi的注释。主要有四个地方:servlet节点、servlet-mapping节点、filter节点、filter-mapping节点。web
仅仅取消注释以后,有可能会发生乱码问题,解决办法是在servlet标签中增长一段配置:apache
<init-param> <param-name>inputEncoding</param-name> <param-value>utf-8</param-value> </init-param> <init-param> <param-name>outputEncoding</param-name> <param-value>utf-8</param-value> </init-param>
4. tomcat这样配置以后,部署在tomcat之上的站点就能够使用include指令了。这样当用户访问时,tomcat若是遇到include指令,就会把include指定的静态页面文件包含到当前页面来。但SSI默认须要在*.shtml文件中才能使用,被引用的文件也得是*.shtml,其实咱们也能够经过配置来让SSI也支持*.html的文件,须要找到servlet-mapping这个节点,在该节点中添加一段代码:tomcat
<url-pattern>*.html</url-pattern>
web.xml文件中关于SSI的部分配置成功以后以下:app
<servlet> <servlet-name>ssi</servlet-name> <servlet-class> org.apache.catalina.ssi.SSIServlet </servlet-class> <init-param> <param-name>buffered</param-name> <param-value>1</param-value> </init-param> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>expires</param-name> <param-value>666</param-value> </init-param> <init-param> <param-name>isVirtualWebappRelative</param-name> <param-value>false</param-value> </init-param> <init-param> <param-name>inputEncoding</param-name> <param-value>utf-8</param-value> </init-param> <init-param> <param-name>outputEncoding</param-name> <param-value>utf-8</param-value> </init-param> <load-on-startup>4</load-on-startup> </servlet> <servlet-mapping> <servlet-name>ssi</servlet-name> <url-pattern>*.shtml</url-pattern> <url-pattern>*.html</url-pattern> </servlet-mapping> <filter> <filter-name>ssi</filter-name> <filter-class> org.apache.catalina.ssi.SSIFilter </filter-class> <init-param> <param-name>contentType</param-name> <param-value>text/x-server-parsed-html(;.*)?</param-value> </init-param> <init-param> <param-name>debug</param-name> <param-value>0</param-value> </init-param> <init-param> <param-name>expires</param-name> <param-value>666</param-value> </init-param> <init-param> <param-name>isVirtualWebappRelative</param-name> <param-value>false</param-value> </init-param> </filter> <filter-mapping> <filter-name>ssi</filter-name> <url-pattern>*.shtml</url-pattern> <url-pattern>*.html</url-pattern> </filter-mapping>
在使用include指令的时候,有两种用法,使用file或使用virtual来指定要引用的文件的路径,以下编辑器
<!--#include file="static/common/header.shtml"--> 或 <!--#include virtual="../static/common/header.shtml"-->
这两种状况必定要弄清楚,拿代码来讲。若是使用file,则当前html文件必定要和static文件夹在同一个目录下,这虽然是一个相对路径的用法,但却不能使用“../”来返回上一个目录,不然页面会出现以下错误:an error occurred while processing this directive。但每每实际中,咱们使用include指令的页面在其它文件夹下,不跟static一个目录,甚至不在一个域名下,这种状况下,就不能使用file,而要使用virtual。virtual是指定一个虚拟路径,使用网站
<!--#include virtual="/static/common/header.shtml"-->
表示指向网站根目录下static文件夹,使用this
<!--#include virtual="http://test.xxx.com/static/common/header.shtml"-->
表示指向test.xxx.com站点下的static文件夹, 使用url
<!--#include virtual="../static/common/header.shtml"-->
表示指向当前文件所在文件夹的上一层文件夹中的static。
参考博文:http://www.blogjava.net/pdw2009/archive/2009/03/06/258270.html