发布日期:2013-12-14 10:22 来源: 标签: JSP 代码 图像
如果您为某个网站编码和提供支持,或者在因特网上拥有一个页面,您就会知道使图像满足所有读者的需要是多么困难。本文推荐了一种解决方案,使用 JavaServer Pages(JSP)标记管理您的图像。
    如果您为某个网站编码和提供支持,或者在因特网上拥有一个页面,您就会知道使图像满足所有读者的需要是多么困难。本文推荐了一种解决方案,使用 JavaServer Pages(JSP)标记管理您的图像。 
    如果您为某个网站编码和提供支持,或者在因特网上拥有一个页面,您就会知道使图像满足所有读者的需要是多么困难。对于偶尔上网的读者以及那些拥有较小显示器或低速拨号连接的读者而言,他们可能更喜欢小图像,大概是 320x240 像素或者更小。而对于其他拥有较大显示器或快速高带宽连接的读者而言,他们可能希望有更大的图像和更多的详细信息。
    控制世界 ? 或者至少控制您的图像
    作为一名站点开发人员或页面作者,迎合所有这些喜好是很困难的。要手工执行该工作,必须将站点上的每个图像转换成您的网站支持的图像大小。然后,需要调整站点上每个页面中的图像标记,使每个标记都正确地反映图像的大小。不能只更改 HTML img 标记的宽(width)和高(height),而不更改图像:这会导致低带宽用户下载大的图像,并在客户机端重新调整它的大小。如果提供了八个常用的图像大小,很容易可以看到每个图像将如何需要八个缩放大小,以及每个页面将如何需要八个版本的图像标记。这类图像管理很乏味而且容易出错,很简单地就能明白为什么大多数网站都不提供多个图像大小。
   问题不在于技术:使用 Java 编程将图像转换成各种大小或格式是很容易的。问题也不在于服务:使用 Web 服务器定制页面以满足个别读者的需要是很常见的。相反,问题在于以易于部署和管理的形式组合技术和服务。
   本文推荐了一种解决方案,使用 JavaServer Pages(JSP)标记管理您的图像。例如,不是象下面那样,在 HTML 中编码图像标记,并且为每个图像大小提供多个版本:
   <img src="images/LazyDog.jpg" width="800" height="600" >
   提供一个可根据读者首选项自动调整图像大小的标记更有意义,如下所示:
   <util:imagesizer src="images/LazyDog.jpg"/>
   让读者从许多大小中选择并且让他们的首选项影响站点上的所有图像,这是可能的,如图 1 中的样本浏览器图像所示。插入宽和高属性,并且消除手工编辑这些标记的苦差事也是可能的。
    图 1. 带有图像首选项的示例 JSP 页面(笑一个)
    可能您以前从未看到过 JSP 定制标记,让我们简单地研究一下本示例中的语法。JSP 定制标记看上去非常象 HTML 标记,但有下列区别:
    有一个由标记开发人员创建的标记名 imagesizer。
    标记有一个前缀 util,它将标记集组合成库,这非常类似于 Java 编程中的包名。您可以创建新的前缀,或者使用与库一起提供的缺省名。
    该标记拥有一个新的类似 XML 的结束标记“/>”。 
    与 HTML 标记一样,JSP 标记可以拥有任意数量的属性,如这里显示的 src 属性,它们可以包含主体,主体中可包含其它标记。由于我们正在模仿 HTML 的 img 标记,所以我们的 JSP 图像缩放标记将没有主体。
    当 JSP 页面使用定制 image-sizer 标记时,标记的 Java 实现找到图像文件,将其转换成合适的大小(在这一过程中可能会添加版权或水印徽标),然后将图像提供给读者。该标记使站点管理器不必在发布前转换图像。它还简化了编写 Web 页面的工作,因为处理许多图像大小首选项只需要一个页面。最后,也是最重要的,为您的所有站点图像提供这类灵活性将赢得读者的青睐。
    Web 服务器上在发生什么
    本节提供了一个高级别视图,介绍了当客户机(读者使用的 Web 浏览器)访问提供 JSP 页面的站点时幕后在发生什么。有三种常见的交互,如图 2 所示:
   图 2. Web 客户机和服务器之间的交互
   在第一种情形中,假定浏览器只请求静态文档,如 HTML 文件或图像文件。服务器在它的文件空间中找到资源,然后将文件提供给浏览器。请求文档和响应请求是在 HTTP 中定义的,HTTP 构成了因特网上客户机/服务器交互的基础。Web 服务器完整地处理请求,无需与 servlet 容器或 Web 应用程序服务器进行交互。
   在第二种情形中,假定浏览器请求包含 Java servlet 的 Web 资源。Java servlet 使 Web 服务器能够在服务器上使用 Java 编程语言执行任务。servlet 很有效,与旧有的技术(如公共网关接口(CGI)、服务器端 JavaScript)相比,使用的内存和处理能力更小。servlet 比其它技术更具有可移植性,因为许多 Web 服务器 ? 如 IBM WebSphere Application Server(Application Server)和 Apache Tomcat 都支持 servlet 容器,而 servlet 容器可以在许多不同的平台上运行相同的 servlet。最后,由于 Java 语言的内在安全性(如健壮的异常处理和细颗粒度安全性),错误的 servlet 很少会影响到 Web 服务器。如图 2 所示,Web 服务器搜索适当的 servlet,如有必要则编译 servlet 源代码,然后将 servlet 的处理结果返回给请求者。经常被请求的 servlet 会高速缓存在服务器的内存中。
    在第三种情形中,假定浏览器请求包含 JSP 页面的 Web 页面。JSP 页面有助于简化显示信息的任务,并且有助于将动态内容(实时生成的)与静态页面分隔开。Web 页面设计人员象使用 HTML 库中的任何其它标记一样使用 JSP 标记。JSP 程序员遵循 JSP 编程规范,并且按照其约定实现标记。
    下一节阐述了如何实现图像缩放 JSP 标记,以及如何编写 JSP 页面。从 Web 容器的观点来看,JSP 页面与 Java servlet 是密切相关的。Web 容器将基于文本的 JSP 页面转换成(每页转换一次)其 Java 实现。Web 容器寻找 Java 实现,将该实现看成 Java servlet,运行代码并将处理结果返回给客户机。这些看上去好象有很多层和重定向,但是对于用户而言,分派是快捷和透明的。象 servlet 一样,经常被请求的 JSP 页面也高速缓存在服务器的内存中。
    编写定制 JSP 标记
    既然明白了 Web 服务器是如何处理 JSP 页面请求的,那么让我们研究一下如何实现定制 JSP 标记。注:JSP 标记既来自标准库(如 Java Standard Template Library,JSTL),也来自您自己编写的库(也称为定制标记)。通常,定制标记处理特殊的问题领域。对本文而言,我们在处理如何管理图像。目前,Java 2 Extended Edition(J2EE)V1.2 和 V1.3 使用 JSP 规范 V1.2。在写作本文的时候,Sun 已经发布了 JSP 规范 V2.0。这个新规范并未对实现定制标记的方法进行重大更改。
    通过 taglib 伪指令,可以将标准和定制标记库导入 JSP 页面,如下所示:
    <%@ taglib uri=´imagesizer.tld´ prefix=´util´ %>
    这个伪指令指定了标记库描述符文件的位置,这里指定的是 imagesizer.tld,还指定了在页面中使用它时的前缀,这里指定的是 util。如前面的标记示例所示,将标记与其前缀及其名称一起使用:
    <util:imagesizer src="images/LazyDog.jpg"/>
    标记库描述符告诉 Web 容器哪些标记是可用的,以及它们如何发挥作用。清单 1 显示了这样一个示例。文件使用了 XML 格式,并且易于读取,而应用程序开发平台 ? 如 IBM WebSphere Studio Application Developer(Application Developer)可以帮助您填充字段,并且验证文件。最重要的信息是 tag 元素:它定义了定制 JSP 标记的名称和实现标记的 Java 类。它还显示了标记接受的任何属性和主体内容。
   清单 1. 标记库描述符(Tag Library Descriptor,TLD)摘录 <taglib >
<tlibversion> 1.0 </tlibversion>
<jspversion> 1.1 </jspversion>
<tag>
<name>imagesizer</name>