tomcat下使用ssi的问题

在tomcat下使用ssi指令的配置以下:html

  1. 找到conf/context.xml这个文件,使用编辑器打开,在<Context>标签中加一句privileged="true",变成<Context privileged="true">java

  2. 找到conf/web.xml这个文件,使用编辑器打开,在文件中查找ssi(原文件中本来就有ssi的配置,只不过被注释了),找到后去掉有关配置ssi的注释。主要有四个地方:servlet节点、servlet-mapping节点、filter节点、filter-mapping节点web

  3. 仅仅取消注释以后,有可能会发生乱码问题,解决办法是在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

                http://blog.csdn.net/5iasp/article/details/7921513

相关文章
相关标签/搜索