简介
SSI (Server Side Includes)是放置在HTML页面里的指令(directives),在HTML页面被使用的同时在服务器上被评估。这样可以让你把新产生的内容添加到现存的HTML页面上,而不需要同过CGI程序,或其他动态的技术来产生整个页面。
当你使用Tomcat作为你的HTTP服务器,并要求有SSI支持,你可以把SSI支持添加到Tomcat里面。通常在你不想要运行一个象Apache的web服务器的开发过程中它就被完成了。
Tomcat SSI 支持实施与Apache相同的指令。关于使用SSI指令的信息,请参看 Apache Introduction to SSI 。
Tomcat里面SSI的支持是通过使用Servlet或过滤器来完成的。你必须选择其中一个来支持你的SSI,而不能同时使用两个。
基于Servlet的SSI是通过实现 org.apache.catalina.ssi.SSIServlet
来完成的。按照SSI的习惯,这个Servlet 然后被映射成以 "*.shtml" 结尾的 URL。
基于过滤器的 SSI 是通过实现 org.apache.catalina.ssi.SSIFilter
来完成的。 按规矩, 这个过滤器过滤所有以"*.shtml"结尾的 URL,你也可以用 "*" 映射,让它过滤所有URL,但它会根据 不同的文件种类(mime types)来决定是否启用SSI。使用初始值 contentType 可以让你决定是否要用 SSI 来处理 JSP, Javascript 或其他内容的网页。
在缺省情况下设置是 Tomcat 不自动启用 SSI。
安装
警告 ——SSI指令可以用于执行Tomcat JVM外部的程序。如果你在使用 Java SecurityManager,它可以绕过你的catalina.policy
里的安全政策配置。
把$CATALINA_BASE/server/lib/servlets-ssi.renametojar 改名为 $CATALINA_BASE/server/lib/servlets-ssi.jar 。
如果选择使用基于Servlet的SSI,请把$CATALINA_BASE/conf/web.xml
里面被注释掉的关于SSI 的 servlet 和 servlet-mapping 定义重新激活。
如果选择基于过滤器的 SSI, 清激活 $CATALINA_BASE/conf/web.xml
关于 SSI 的 filter 和 filter-mapping的设置。 .
Servlet 设置
有几个servlet起始参数可以用来配置SSI servlet的行为。
buffered - 这个servlet的输出是不是应该被缓冲?(0=false, 1=true) 默认是 0 (false). debug - 由这个servlet日志的排错消息的详细程度。默认是0。 expires - 带有SSI指令的页面失效之前的秒数。默认行为是对于每一个请求都要评估所用的SSI指令。 isVirtualWebappRelative - “虚拟”SSI指令路径是否应该被解释为相对于context root,而不是server root。 (0=false, 1=true) 默认是 0 (false)。 inputEncoding - 如果无法决定所调用资源的文字编码,SSI应该使用的编码。缺省数值是系统的文字编码。 outputEncoding - 输出结果的文字编码,缺省值是 UTF-8。
过滤器设置
过滤器的性能可通过修改几个不同的初始值来调整。
contentType - 用一个正则表达式来就定那种网页类型应该调用 SSI。在决定正则表达式时,不要忘记在网页内容种类的定义里可以有文字编码的选项,它的标准是:"mime/type; charset=set",其中 charset=set 是选择项。 contentType的缺省值是:"text/x-server-parsed-html(;.*)?". debug - 由这个servlet日志的排错消息的详细程度。默认是0。 expires - 带有SSI指令的页面失效之前的秒数。默认行为是对于每一个请求都要评估所有的SSI指令。 isVirtualWebappRelative - “虚拟”SSI指令路径是不是应该被解释为相对于 context root相关,还是相对于server root (0=false, 1=true) 默认是 0 (false)。
Tomcat 允许 SSI 指令
SSI是通过 嵌入在 HTML的指令来完成的实现动态网页的。这些指令在HTML里面如同HTML的注释,在运行Tomcat会把它替换为响应的内容。这些指令的标准格式是:
<!--#directive [parm=value] -->
有效指令有:
config - <!--#config timefmt="%B %Y" -->
用来指定SSI输出的时间日期或其他内容的格式 echo - <!--#echo var="VARIABLE_NAME" -->
替换所指定的数值 exec - 运行所在系统的命令 include - <!--#include virtual="file-name" -->
插入内容 flastmod - <!--#flastmod file="filename.shtml" -->
文件最后修改时间 fsize - <!--#fsize file="filename.shtml" -->
文件大小 printenv - <!--#printenv -->
打印所有环境变量 set - <!--#set var="foo" value="Bar" -->
用来为用户定义变量赋值 if elif endif else - 用于条件判断,例如: <!--#config timefmt="%A" --> <!--#if expr="$DATE_LOCAL = /Monday/" --> <p>Meeting at 10:00 on Mondays</p> <!--#elif expr="$DATE_LOCAL = /Friday/" --> <p>Turn in your time card</p> <!--#else --> <p>Yoga class at noon.</p> <!--#endif -->
阅读更多SSI相关内容:
Apache SSI入门
Variables
SSI Servlet 现在支持下列变量:
变量名称 描述 AUTH_TYPE 用来验证用户的方法,可以是:BASIC, FORM, 等 CONTENT_LENGTH 从FORM传来的数据长度,单位是 bytes 或字符的个数 CONTENT_TYPE MIME种类, 例如 "text/html" DATE_GMT 现在的国际标准时间 GMT DATE_LOCAL 当地时间 DOCUMENT_NAME 调用的文件名 DOCUMENT_URI 文件的虚拟路径 GATEWAY_INTERFACE 服务器如果激活了 CGI 的话,显示支持的 CGI 版本,如 "CGI/1.1" HTTP_ACCEPT 所有允许的 MIME 种类 HTTP_ACCEPT_ENCODING 列出所有客户端允许的压缩方式 HTTP_ACCEPT_LANGUAGE 列出所有客户端接受的语言 HTTP_CONNECTION 客户端接受的连接管理方法,如 "Close" or "Keep-Alive" HTTP_HOST 用户请求访问的网站 HTTP_REFERER 连接到本网页的网页地址,用户来自于的网页网页 HTTP_USER_AGENT 浏览器的名称 LAST_MODIFIED 当前文件的最后修改时间 PATH_INFO 传给服务器的路径信息 PATH_TRANSLATED 经过转换的 PATH_INFO 路径 QUERY_STRING 浏览器地址栏里 "?" 之后的值 QUERY_STRING_UNESCAPED Undecoded query string with all shell metacharacters escaped with "/" REMOTE_ADDR 用户的IP地址 REMOTE_HOST 用户的网址 REMOTE_PORT 用户所用的端口号码 REMOTE_USER 经确认的用户名字 REQUEST_METHOD 用户请求访问所使用的方法,如 "GET", "POST" 等 REQUEST_URI 用户所要求访问的网址 SCRIPT_FILENAME 目前用户实际访问的网页在服务器上的文件名 SCRIPT_NAME 网页的文件名 SERVER_ADDR 服务器的IP地址 SERVER_NAME 服务器电脑的名称或IP SERVER_PORT 服务器等待用户访问的端口 SERVER_PROTOCOL 服务器使用的协议,如: "HTTP/1.1" SERVER_SOFTWARE 服务器所使用的软件名称和版本数 UNIQUE_ID 服务器与用户目前如果开始会话的特有ID
另一篇实用性的文章中的内容如下:
在目前的Tomcat中,shtml默认是不支持的,需要进行一定的配置,其实也不是非常复杂,不同的Tomcat版本,配置方法也有所不同,参考方法如下: Tomcat5.x版的配置方法: 1.在$CATALINA_BASE/server/lib/目录下找到servlets-ssi.renametojar文件,将这个文件重命名为servlets-ssi.jar 2.在$CATALINA_BASE/conf/目录下找到web.xml文件 3.使用SSI Servlet的话删除在SSI servlet和servlet-mapping周围的注释,使用SSI filter的话删除在SSI filter和filter-mapping周围的注释 tomcat 6 SSI的配置与5.x版本不同,下面介绍tomcat 6 SSI的配置方法 Tomcat6版的配置方法: 1.在$CATALINA_BASE/conf/目录下找到web.xml文件 2.使用SSI Servlet的话删除在SSI servlet和servlet-mapping周围的注释,使用SSI filter的话删除在SSI filter和filter-mapping周围的注释 3.$CATALINA_BASE/conf/下还有一个context.xml,将里面的<Context>改成<Context privileged="true"> 4.解决乱码问题 在$CATALINA_BASE/conf/web.xml中的ssi servlet配置中添加以下初始配置: <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> 其中utf-8编码应该和你页面的编码方式一样 更多请参考官方的配置说明http://tomcat.apache.org/tomcat-6.0-doc/ssi-howto.html 经过上面的配置,包含文件: <!--#include file="include.html" --> <!--#include virtual="include.html" --> 才可以正常显示。