tomcat ssi配置

SSI How To



 
简介

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_TYPEMIME种类, 例如 "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_UNESCAPEDUndecoded 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" -->
才可以正常显示。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值